美文网首页
MySQL基础01-数据类型

MySQL基础01-数据类型

作者: 四月不见 | 来源:发表于2019-03-12 15:27 被阅读0次

    一、整数类型

    每个整型类型可以指定一个最小显示宽度(注意:这个宽度并不表示存储的值有多大)

    类型 存储空间(N) 取值范围:-2(N-1)到 2(N-1)-1
    TINYINT 8 -128……127
    SMALLINT 16 -32768……32767
    MEDIUMINT 24 -8388608……8388607
    INT 32 -2147483648……2147483647
    BIGINT 64 (自己算... ...)

    注:如果有指定UNSIGNED属性,则存取范围可以提升一倍,
    即:-2N到 2N-1

    基本格式:

    INT[(M)] [UNSIGNED] [ZEROFILL]
    

    ① M:指定显示宽度(默认是M=10),以实际的取值范围为准,值超过显示宽度,显示宽度自动增加
    ② unsigned:无符号的,表示只允许正数,所以取值范围取绝对值且最大值*2
    ③ zerofill: 填充0(如果声明了zerofill,该列会自动设为unsigned)

    二、实数类型

    1、定点小数:decimal

    基本格式:

    DEC[(M[,D])] [UNSIGNED] [ZEROFILL]
    

    ① M:精度,(整数位数+小数位数)不包含小数点的数字总位数(1--30),不指定默认为10
    ② D:小数位数,如果不指定,默认为0

    注: 若位数不够,小数末尾补零;若位数超预算,则报错。

    2、浮点数:float与double

    基本格式:

    float[(length) | (<display width>,<scale>)]
    double[(precision) | (<display width>,<scale>)]
    

    两者区别在于值所保留的存储空间数量不同

    注:由于对一个浮点数字来说,可用的存储空间有限,如果一个数字非常大或非常小,将存储这个数字的近似值而不是实际值。

    使用方法:

    ① 使用一个参数来指定浮点类型
    length/precision:在一个浮点数据类型中可以指定长度,来确定具体的浮点类型。
    0~24:单精度float,从第7位有效位,进行四舍五入存储
    25~30:双精度double,从第16位有效位,进行四舍五入存储
    如:

    mysql> create table t3(id float(8));
    //m=8,说明是单精度,存储6位的近似值(第7位四舍五入,后面为0)
    mysql> insert into t3 values(123);
    mysql> insert into t3 values(1234567);
    mysql> insert into t3 values(123456789);
    mysql> insert into t3 values(123456789.123456789);
    
    mysql> select * from t3;
    +-----------+
    | id        |
    +-----------+
    | 123       |
    | 1234570   |
    | 123457000 |
    | 123457000 |
    +-----------+
    

    ② 使用两个参数来指定浮点类型
    单精度float(m,d):m表示精度(0~24),d表示小数位数
    双精度double(m,d):m表示精度(25~30),d表示小数位数
    注意:整数位(m-d)不够没关系,超出报错;小数位(d)不够补零,超出四舍五入。

    三、字符串

    类型 描述
    char(n) 固定长度,最多255个字符。char非常适合用于存储密码的MD5值
    varchar(n) 可变长度,最多65535个字符。varchar需要使用1或2个额外字节记录字符串长度:如果列的最大长度小于或等于255字节,则使用1个字节表示,否则使用2个字节。
    TEXT 包括TINYTEXT、SMALLTEXT(TEXT)、MEDIUMTEXT、LONGTEXT
    BLOB 包括TINYBLOB、SMALLBLOB(BLOB)、MEDIUMBLOB、LONGBLOB,二进制类型。BLOB 可以储存图片。

    1、char和varchar
    区别:
    ① char(n) 若存入字符数小于n,则以空格补于其后,查询之时再将空格去掉。所以char类型存储的字符串末尾不能有空格,varchar不限于此。
    ② char(n) 固定长度,char(4)不管是存入几个字符,都将占用4个字节,varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),所以varchar(4),存入3个字符将占用4个字节。
    ③ char类型的字符串检索速度要比varchar类型的快。
    ④ 对于经常更变的数据,char比varchar更好,char不容易产生碎片。
    相同:
    ① 如果存储内容走出指定长度,都会被截断。

    2、varchar和text的区别:
    ① varchar可指定n,text不能指定,内部存储varchar是存入的实际字符数+1个字节(n<=255)或2个字节(n>255),text是实际字符数+2个字节。
    ② text类型不能有默认值。
    ③ varchar可直接创建索引,text创建索引要指定前多少个字符。varchar查询速度快于text,在都创建索引的情况下,text的索引似乎不起作用。
    ④ char和varchar可以有默认值,text不能指定默认值。

    注:尽量避免使用BLOB/TEXT类型,查询会使用临时表,导致严重的性能开销。

    四、枚举

    枚举可以把一些不重复的字符串存储成一个预定的集合。MySQL在存储枚举时非常紧凑,会根据列表值的数量压缩到一个或者两个字节中。MySQL在内部会将每个值在列表中的位置保存为整数,并且在表的.frm文件中保存“数字 - 字符串”映射关系的“查找表”。

    注:尽量避免使用数据作为ENUM枚举的常量,易混乱。

    五、时间和日期

    类型 描述
    DATETIME 表示时间范围是1001年到9999年,精度为秒。占用8个字节。
    TIMESTAMP 占用4个字节,表示时间范围从1970年到2038年。使用该类型时一定要注意时区问题。

    六、位

    位主要是用来存放二进制数,select查询默认显示10进制,可以使用bin()、hex()函数来进行查询。

    bin()---显示二进制格式
    hex()---显示十六进制格式

    如:

    mysql> create table t(id bit(4));
    
    mysql> insert into t values(2);
    mysql> insert into t values(13);
    
    mysql> select bin(id),hex(id) from t;
    +---------+---------+
    | bin(id) | hex(id) |
    +---------+---------+
    | 10      | 2       |
    | 1101    | D       |
    +---------+---------+ 
    

    参考

    《高性能MySQL》 [美]Baron Scbwartz, Peter Zaitsev, Vadim Tkacbenko 著

    相关文章

      网友评论

          本文标题:MySQL基础01-数据类型

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