美文网首页
04,列类型与建表语句-1数值型

04,列类型与建表语句-1数值型

作者: 小碧小琳 | 来源:发表于2018-11-10 21:37 被阅读0次

    目的,要学会建表
    需要学会的知识点:列类型

    怎么建表?

    分析:我们只要把第一行,表头建好了,这张表也就完成了。
    至于下面的001,张三,这不是表的概念,而是表中存储的数据。

    其实,建表过程,就是一个画表头的过程。
    从术语上将,这张表有4个列,建表的过程,就是一个声明字段的过程。

    那么建表和列类型又有什么关系呢?
    分析:再看上面的表,A4纸是数据的存储空间,而A4纸的大小是固定的
    请问:你准备给学号,姓名等留多宽?
    (如果姓名留很宽,比如能存20个字,但是一般人的姓名,就三四个字,就会导致浪费空间。
    如果留的过窄,导致存不下,就更有问题。)

    对应的A4纸空间有限,硬盘空间也有限。
    我们建列时,自然想到的是:能够容纳放置的内容,但是又不浪费。

    存储同样的数据,不同的列类型,所占据的空间和效率,是不一样的。这就是我们建表前,要学习列类型的意义。

    怎样选择合理的列类型,使其能合理的利用空间?

    MySQL三大列类型

    一、数值型(分为整型与浮点型)

    整型:tinyint,smallint,mediumint,int,bigint。
    (分别占,1,2,3,4,8个字节)

    1、整型以tinyint为例

    需要关心的事情有两个

    • 1、占据多大空间?
      1字节
    • 2、能存多大的数?
      -128~127
      0~255

    对于什么时候明确用有符号的,什么时候用无符号的。这就涉及到int系列的声明时的参数了:(M) unsigned zerofill

    1.1、unsigned参数

    那么需要发问:对于声明tinyint,怎么让他0-255,怎么让他-128 - 127?

    当我们建表时,数据默认是有符号的!因此,默认是-128~127的。

    在列类型后加unsigned,表示其为无符号类型。

    1.2、M参数必须和zerofill配合才有意义(代表0填充)

    比如,给学员增加一个学号列

    • 学号不能为负
    • 学号一般位数相同,即使不同,补到一个固定的长度(比如00013,02138)
      不够位数,用0填充

    如上图,如令M等于5,则配合zerofill使用,补0,补到5位。

    观察snum的类型,可知zerofill则同时必是unsigned类型。

    ————————————————————————————————

    对于上面问题,再次发问怎样选择合理的列类型,使其能合理的利用空间?

    比如,
    对于同学的年龄,我们用tinyint类型即可有效存储。
    对于乌龟的年龄,我们用smallint类型可以有效表示。
    对于中国的社保号,用int unsigned(四十多亿)来表示。
    ————————————————————————————————

    2、浮点型

    float(M,D) ,decimal(M,D)
    M叫“精度” ==》 代表小数的“总位数”
    D是“标度” ==》代表小数位(小数点右边的位数)

    1、float类型

    比如float(6,2)代表的是-9999.99 ~ +9999.99.

    另外,可以给float用unsigned参数,让其成为无符号。比如对于奖金,不能为负数,只能为正数。

    浮点数,占多大的空间呢?
    答:

    • 存储范围
      float能存10^38. 10^-38。(不必细究存储范围,这是系统定下来的)
    • 占用空间
      如果M小于等于24,那么就占4个字节,否则占8个字节。

    2、decimal

    decimal,叫定点(把整数部分和小数部分,分开存储的),比float精确。
    (decimal属于变长类型)

    比如,在银行账户中,我们一般要求精确的存储用户的余额,这里看一下float 与decimal类型的对比。这里我们建立一个account的表,

    对于id=1的用户,插入相同的数字1234567.23.看结果

    明显能够看到结果,float存储有时会损失精度。像账户这样的敏感字段,建议用decimal类型存储。
    (一般银行,用整型存储账户余额,存储的单位是“分”)

    浮点数在计算机里表示是比较复杂的。

    比如,对于234.87, --- 23.487
    那么,小数点左边能达到多少,小数点右边又能达到多少?(可以暂时不用管,比较复杂。)

    相关文章

      网友评论

          本文标题:04,列类型与建表语句-1数值型

          本文链接:https://www.haomeiwen.com/subject/czvoxqtx.html