zoukankan      html  css  js  c++  java
  • { MySQL基础数据类型}一 介绍 二 数值类型 三 日期类型 四 字符串类型 五 枚举类型与集合类型

    MySQL基础数据类型

    一 介绍

      存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的

      详细参考:

    • http://www.runoob.com/mysql/mysql-data-types.html
    • http://dev.mysql.com/doc/refman/5.7/en/data-type-overview.html

      mysql常用数据类型概览:

    复制代码
    #1. 数字:
        整型:tinyinit  int  bigint
        小数:
            float :在位数比较短的情况下不精准
            double :在位数比较长的情况下不精准
                0.000001230123123123
                存成:0.000001230000
    
            decimal:(如果用小数,则用推荐使用decimal)
                精准
                内部原理是以字符串形式去存
    
    #2. 字符串:
        char(10):简单粗暴,浪费空间,存取速度快
            root存成root000000
        varchar:精准,节省空间,存取速度慢
    
        sql优化:创建表时,定长的类型往前放,变长的往后放
                        比如性别           比如地址或描述信息
    
        >255个字符,超了就把文件路径存放到数据库中。
                比如图片,视频等找一个文件服务器,数据库中只存路径或url。
    
    
    
    #3. 时间类型:
        最常用:datetime
    
    
    #4. 枚举类型与集合类型
    复制代码

    二 数值类型

      1、整数类型

        整数类型:TINYINT,SMALLINT,MEDIUMINT,INT,BIGINT

        作用:存储年龄,等级,id,各种号码等

    整数类型分类
    整数类型范围验证

        注意:对于整型来说,数据类型后面的宽度并不是存储长度限制,而是显示限制,假如:int(8),那么显示时不够8位则用0来填充,够8位则正常显示,通过zerofill来测试,存储长度还是int的4个字节长度。默认的显示宽度就是能够存储的最大的数据的长度,比如:int无符号类型,那么默认的显示宽度就是int(10),有符号的就是int(11),因为多了一个符号,所以我们没有必要指定整数类型的数据,没必要指定宽度,因为默认的就能够将你存的原始数据完全显示

        

        int的存储宽度是4个Bytes,即32个bit,即2**32  

        无符号最大值为:4294967296-1

        有符号最大值:2147483648-1

        有符号和无符号的最大数字需要的显示宽度均为10,而针对有符号的最小值则需要11位才能显示完全,所以int类型默认的显示宽度为11是非常合理的

        最后:整形类型,其实没有必要指定显示宽度,使用默认的就ok

     
    说到这里我想提一下MySQL的mode设置,看我这篇博客:https://www.cnblogs.com/clschao/articles/9962347.html,看完博客应该就能理解MySQL的mode了。

      2、浮点型

        定点数类型  DEC,等同于DECIMAL  

        浮点类型:FLOAT DOUBLE

        作用:存储薪资、身高、温度、体重、体质参数等

    浮点型分类
    浮点型测试

      3、位类型(了解,不讲~~)

        BIT(M)可以用来存放多位二进制数,M范围从1~64,如果不写默认为1位。
        注意:对于位字段需要使用函数读取
            bin()显示为二进制
            hex()显示为十六进制

    位类型测试

    三 日期类型

      类型:DATE,TIME,DATETIME ,IMESTAMP,YEAR 

      作用:存储用户注册时间,文章发布时间,员工入职时间,出生时间,过期时间等

    日期类型分类

      

    日期类型测试

      mysql的日期格式对字符串采用的是'放松'政策,可以以字符串的形式插入。

    datetime与timestamp的区别

      工作中一般都用datetime就可以了。 

    对上面datetime与timestamp的区别中第四条的验证

    四 字符串类型

      类型:char,varchar

      作用:名字,信息等等

    char和varchar的介绍

      下面我们来进行一些测试,在测试之前,我们需要学一下mysql给我们提供的两个方法:

        length(字段):查看该字段数据的字节长度

        char_length(字段):查看该字段数据的字符长度

    char和varchar测试

      测试结果总结:
      针对char类型,mysql在存储的时候会将不足规定长度的数据使用后面(右边补全)补充空格的形式进行补全,然后存放到硬盘中,但是在读取或者使用的时候会自动去掉它给你补全的空格内容,因为这些空格并不是我们自己存储的数据,所以对我们使用者来说是无用的。

      char和varchar性能对比:
        以char(5)和varchar(5)来比较,加入我要存三个人名:sb,ssb1,ssbb2
        char:
          优点:简单粗暴,不管你是多长的数据,我就按照规定的长度来存,5个5个的存,三个人名就会类似这种存储:sb ssb1 ssbb2,中间是空格补全,取数据的时候5个5个的取,简单粗暴速度快
          缺点:貌似浪费空间,并且我们将来存储的数据的长度可能会参差不齐

        varchar:
          varchar类型不定长存储数据,更为精简和节省空间
          例如存上面三个人名的时候类似于是这样的:sbssb1ssbb2,连着的,如果这样存,请问这三个人名你还怎么取出来,你知道取多长能取出第一个吗?(超哥,我能看出来啊,那我只想说:滚犊子!)
          不知道从哪开始从哪结束,遇到这样的问题,你会想到怎么解决呢?还记的吗?想想?socket?tcp?struct?把数据长度作为消息头。

          
          所以,varchar在存数据的时候,会在每个数据前面加上一个头,这个头是1-2个bytes的数据,这个数据指的是后面跟着的这个数据的长度,1bytes能表示2**8=256,两个bytes表示2**16=65536,能表示0-65535的数字,所以varchar在存储的时候是这样的:1bytes+sb+1bytes+ssb1+1bytes+ssbb2,所以存的时候会比较麻烦,导致效率比char慢,取的时候也慢,先拿长度,再取数据。

          优点:节省了一些硬盘空间,一个acsii码的字符用一个bytes长度就能表示,但是也并不一定比char省,看一下官网给出的一个表格对比数据,当你存的数据正好是你规定的字段长度的时候,varchar反而占用的空间比char要多。

    ValueCHAR(4)Storage RequiredVARCHAR(4)Storage Required
    '' '    ' 4 bytes '' 1 byte
    'ab' 'ab  ' 4 bytes 'ab' 3 bytes
    'abcd' 'abcd' 4 bytes 'abcd' 5 bytes
    'abcdefgh' 'abcd' 4 bytes 'abcd' 5 bytes

            
          缺点:存取速度都慢

      总结:
        所以需要根据业务需求来选择用哪种类型来存
        其实在多数的用户量少的工作场景中char和varchar效率差别不是很大,最起码给用户的感知不是很大,并且其实软件级别的慢远比不上硬件级别的慢,所以你们公司的运维发现项目慢的时候会加内存、换nb的硬盘,项目的效率提升的会很多,但是我们作为专业人士,我们应该提出来这样的技术点来提高效率。

        但是对于InnoDB数据表,内部的行存储格式没有区分固定长度和可变长度列(所有数据行都使用指向数据列值的头指针),因此在本质上,使用固定长度的CHAR列不一定比使用可变长度VARCHAR列性能要好。因而,主要的性能因素是数据行使用的存储总量。由于CHAR平均占用的空间多于VARCHAR,因此使用VARCHAR来最小化需要处理的数据行的存储总量和磁盘I/O是比较好的。

        所以啊,两个选哪个都可以,如果是大型并发项目,追求高性能的时候,需要结合你们服务器的硬件环境来进行测试,看一下char和varchar哪个更好,这也能算一个优化的点吧~~~~

      

    官网详解

      其他的字符串类型:BINARY、VARBINARY、BLOB、TEXT

      

    其他类型简单介绍

    五 枚举类型与集合类型

      字段的值只能在给定范围中选择,如单选框,多选框,如果你在应用程序或者前端不做选项限制,在MySQL的字段里面也能做限制
      enum 单选 只能在给定的范围内选一个值,如性别 sex 男male/女female
      set 多选 在给定的范围内可以选择一个或一个以上的值(爱好1,爱好2,爱好3...)

    复制代码
              枚举类型(enum)
                An ENUM column can have a maximum of 65,535 distinct elements. (The practical limit is less than 3000.)
                示例:
                    CREATE TABLE shirts (
                        name VARCHAR(40),
                        size ENUM('x-small', 'small', 'medium', 'large', 'x-large')
                    );
                    INSERT INTO shirts (name, size) VALUES ('dress shirt','large'), ('t-shirt','medium'),('polo shirt','small');
    
      
    
              集合类型(set)
                A SET column can have a maximum of 64 distinct members.
                示例:
                    CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
                    INSERT INTO myset (col) VALUES ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
    复制代码
    测试
  • 相关阅读:
    docker知识3---镜像
    docker知识2---docker简介
    docker知识1---容器背景
    docker故障排查
    linux故障处理--ssh故障
    sqlalchemy的一行代码更新数据库
    Python内置函数和高阶函数(map,filter,reduce, sorted,enumerate, zip,单行条件语句 )
    Mysql略复杂命令总结
    pip的使用
    Linux的基础命令
  • 原文地址:https://www.cnblogs.com/16795079a/p/10445300.html
Copyright © 2011-2022 走看看