MySQL的数据类型

1 数值类型

    注:整型的数据默认有符号;
      若超出的范围,低的显示最的范围,高的显示最高范围;
      可以指定显示宽度,int(3),但是显示宽度不一定等于存储宽度(默认的显示宽度,都是在最大值的基础上      加1)
        ======用zerofill测试整数类型的显示宽度=============
        mysql> create table t7(x int(3) zerofill);  # 自动补0
    小整数:
        tinyint[(m)] [unsigned] [zerofill]
            有符号: -128 ~ 127 无符号: 0 ~ 255 PS: MySQL中无布尔值,使用tinyint(1)构造。

    ======================================
    #FLOAT[(M,D)] [UNSIGNED] [ZEROFILL]

    定义:
            单精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30
    有符号:
               -3.402823466E+38 to -1.175494351E-38,
               1.175494351E-38 to 3.402823466E+38
    无符号:
               1.175494351E-38 to 3.402823466E+38
    精确度: 
               **** 随着小数的增多,精度变得不准确 ****

    ======================================
    #DOUBLE[(M,D)] [UNSIGNED] [ZEROFILL]

    定义:
               双精度浮点数(非准确小数值),m是数字总个数,d是小数点后个数。m最大值为255,d最大值为30
    有符号:
               -1.7976931348623157E+308 to -2.2250738585072014E-308
               2.2250738585072014E-308 to 1.7976931348623157E+308
    无符号:
               2.2250738585072014E-308 to 1.7976931348623157E+308
    精确度:
               ****随着小数的增多,精度比float要高,但也会变得不准确 ****

    ======================================
    decimal[(m[,d])] [unsigned] [zerofill]

    定义:
              准确的小数值,m是数字总个数(负号不算),d是小数点后个数。 m最大值为65,d最大值为30。
    精确度:
               **** 随着小数的增多,精度始终准确 ****
               对于精确数值计算时需要用此类型
               decaimal能够存储精确值的原因在于其内部按照字符串存储。

2 时间与日期

        YEAR
            YYYY(1901/2155)
        DATE
            YYYY-MM-DD(1000-01-01/9999-12-31)
        TIME
            HH:MM:SS('-838:59:59'/'838:59:59')
        DATETIME
            YYYY-MM-DD HH:MM:SS(1000-01-01 00:00:00/9999-12-31 23:59:59    Y)
        TIMESTAMP
            YYYYMMDD HHMMSS(1970-01-01 00:00:00/2037 年某时)

     注意:  1.需要以字符串的形式,按照对应的格式插入 ;若要插入当前时间,用now()函数              
            2. 插入年份时,尽量使用4位值               
            3. 插入两位年份时,<=69,以20开头,比如50, 结果2050                  
                         >=70,以19开头,比如71,结果1971

       datetime与timestamp的区别:
         1.DATETIME的日期范围是1001——9999年,TIMESTAMP的时间范围是1970——2038年。
         2.DATETIME存储时间与时区无关,TIMESTAMP存储时间与时区有关,显示的值也依赖于时区。在mysql服务器,
         操作系统以及客户端连接都有时区的设置。
         3.DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。因此,TIMESTAMP比DATETIME的空间利用率更高。
         4.DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),
         如果不做特殊处理,并且update语句中没有指定该列的更新值,则默认更新为当前时间。

3 字符串类型

    #注意:char和varchar括号内的参数指的都是字符的长度

    1 char类型:定长,简单粗暴,浪费空间,存取速度快
        字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)
        存储:
            存储char类型的值时,会往右填充空格来满足长度
        检索:
            在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开(mysql>SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)

        比如,mysql> select char_length(x),char_length(y) from t1; # 一个存3取3(保留存入状态),一个存5取2(舍去后面的空格)
        (length:查看字节数     char_length:查看字符数)

        因为这种机制,对于char类型在检索时:
             mysql>select name from t1 where name="李杰"; # 可以查到
             mysql>select name from t1 where name like "李杰"; # 不能查到,必须改为"李杰 "


    2 varchar类型:变长,精准,节省空间,存取速度慢
        字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:
        存储:
            varchar类型存储数据的真实内容,不会用空格填充,如果'ab  ',尾部的空格也会被存起来
            强调:varchar类型会在真实数据前加1-2Bytes的前缀,该前缀用来表示真实数据的bytes字节数(1-2Bytes最大表示65535个数字,正好符合mysql对row的最大字节限制,即已经足够使用)
            如果真实的数据<255bytes则需要1Bytes的前缀(1Bytes=8bit 2**8最大表示的数字为255)
            如果真实的数据>255bytes则需要2Bytes的前缀(2Bytes=16bit 2**16最大表示的数字为65535)

        检索:
            尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容
        Note:
        实际中对于一串的数据“ad cc  dds”,char类型可以直接定长读取;而varchar要有一个表头,表示每次应读几个字符。

        注:虽然varchar使用起来较为灵活,char数据类型的处理速度(存取时)更快。
            一章表中char与varchar不要混合使用;一般将char类型放前面,varchar放后面。


    3 其他字符串系列(效率:char>varchar>text)
        TEXT系列 TINYTEXT TEXT MEDIUMTEXT LONGTEXT
            text:text数据类型用于保存变长的大字符串,可以组多到65535 (2**16 − 1)个字符。
            mediumtext:A TEXT column with a maximum length of 16,777,215 (2**24 − 1) characters.
            longtext:A TEXT column with a maximum length of 4,294,967,295 or 4GB (2**32 − 1) characters.
        BLOB 系列    TINYBLOB BLOB MEDIUMBLOB LONGBLOB 
        BINARY系列 BINARY VARBINARY

4 枚举类型与集合类型

     enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female
     set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)

    MariaDB [db1]> create table consumer( 
        -> name varchar(50),
        -> sex enum('male','female'),
        -> level enum('vip1','vip2','vip3','vip4','vip5'), #在指定范围内,多选一
        -> hobby set('play','music','read','study') #在指定范围内,多选多
        -> );

    MariaDB [db1]> insert into consumer values  
        -> ('egon','male','vip5','read,study'),
        -> ('alex','female','vip1','girl');

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值