美文网首页
MySQL数据类型

MySQL数据类型

作者: Claire_wu | 来源:发表于2018-12-26 15:19 被阅读8次

    1 MySQL数据类型

    1.1 整型

    image.png

    取值范围如果加了 unsigned,则最大值翻倍,如 tinyint unsigned 的取值范围为(0~256)。
    int(m) 里的 m 是表示 SELECT 查询结果集中的显示宽度,并不影响实际的取值范围,没有影响到显示的宽度,不知道这个 m 有什么用。

    1.2 浮点型(float 和 double)

    image.png

    设一个字段定义为 float(5,3),如果插入一个数 123.45678,实际数据库里存的是 123.457,但总个数还以实际为准,即 6 位。

    1.3 定点数

    浮点型在数据库中存放的是近似值,而定点类型在数据库中存放的是精确值。
    decimal(m,d) 参数 m<65 是总个数,d<30 且 d<m 是小数位。

    1.4 字符串(char,varchar,_text)

    image.png

    char 和 varchar:

    1. char(n) 若存入字符数小于n,则以空格补于其后,查询之时再将空格去掉。所以 char 类型存储的字符串末尾不能有空格,varchar 不限于此。
    2. char(n) 固定长度,char(4) 不管是存入几个字符,都将占用 4 个字节,varchar 是存入的实际字符数 +1 个字节(n<=255)或2个字节(n>255),所以 varchar(4),存入 3 个字符将占用 4 个字节。
    3. char 类型的字符串检索速度要比 varchar 类型的快。

    varchar 和 text:

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

    1.5 二进制数据(_Blob)

    1. _BLOB和_text存储方式不同,_TEXT以文本方式存储,英文存储区分大小写,而_Blob是以二进制方式存储,不分大小写。
    2. _BLOB存储的数据只能整体读出。
    3. _TEXT可以指定字符集,_BLO不用指定字符集。

    1.6 日期时间类型

    image.png

    若定义一个字段为timestamp,这个字段里的时间数据会随其他字段修改的时候自动刷新,所以这个数据类型的字段可以存放这条记录最后被修改的时间。

    2 MySQL 检查长度

    MySQL支持多种类型,大致可以分为三类:数值、日期/时间和字符串(字符)类型。
    MySQL 5.0 以上的版本:

    1. 一个汉字占多少长度与编码有关:
      UTF-8:一个汉字=3个字节
      GBK:一个汉字=2个字节

    2. varchar(n) 表示 n 个字符,无论汉字和英文,Mysql 都能存入 n 个字符,仅是实际字节长度有所区别

    3. MySQL 检查长度,可用 SQL 语言来查看:

    select LENGTH(fieldname) from tablename
    

    3 MySQL 数据类型的属性

    image.png

    4 参考资料

    MySQL 数据类型

    相关文章

      网友评论

          本文标题:MySQL数据类型

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