10月23日学习内容整理:表操作的数据类型,约束条件

一、数据类型

1、数值类型:

(1)整数类型

》分类:TINYINT  SMALLINT  MEDIUMINT  INT  BIGINT

注意:

》》整型的宽度指的是显示宽度,并不是存储宽度,默认是11,使用zerofill约束代表用0填充空余位

》》合理选择整数类型,一般INT就已经够用了,不能因为BIGINT范围大就全用它

》》整型通常不用去指定宽度,默认宽度是11,足够用

》》整数类型都是默认有符号的,使用unsigned约束代表改为无符号的,这时默认宽度就变为10

========================================
        tinyint[(m)] [unsigned] [zerofill]

            小整数,数据类型用于保存一些范围的整数数值范围:
            有符号:
                -128 ~ 127
            无符号: 0 ~ 255

            PS: MySQL中无布尔值,使用tinyint(1)构造。



========================================
        int[(m)][unsigned][zerofill]

            整数,数据类型用于保存一些范围的整数数值范围:
            有符号:
                    -2147483648 ~ 2147483647
            无符号: 0 ~ 4294967295



========================================
        bigint[(m)][unsigned][zerofill]
            大整数,数据类型用于保存一些范围的整数数值范围:
            有符号:
                    -9223372036854775808 ~ 9223372036854775807
            无符号: 0 ~  18446744073709551615
整型小结

 

(2)浮点类型

》分类:float(单精度)  double(双精度)  decimal(准确)

》范围:默认也是有符号的

——>float(m,n) 5指的是数字总位数,3指的是小数位数

——>float类型m最大255,n最大30

——>double类型m最大255,n最大30

——>decimal类型m最大65,n最大30

》精度:三种类型的精度是由低到高的

======================================
#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能够存储精确值的原因在于其内部按照字符串存储。
浮点小结

 

 (补充:范围的计算方法:以1个字节为例
1个字节是8位,每一位都是0或1两种情况,那么一共有2的8次方也就是256种可能但是实际上是从0开始的,所以最大值只能取到255,如果取256的话就是257种可能了(因为是整数,是从0开始依次增大的,跟有多少种可能是跟数值是一一对应的),这是无符号的情况

有符号的情况下,有一位用0或1代表正负,所以实际上表示数字的只有7位,那么正数的部分和无符号的分析一样,那负数的部分因为是从-1开始的,所以有多少种可能就有多少个数值,2的7次方是128,也就是说负数部分应该有128种可能,又因为从-1开始,所以最小值能取到-128

 

 

了解:位类型BIT:

 bit(M)M代表存储位数

取的时候利用mysql函数 :

select   bin(*) from  table1   bin是转换为二进制,hex是十六进制

 

 

2、日期类型:

》分类:

date:2017-11-11

time:10:19:43

datetime:2014-12-23 10:23:33

timestamp:2014-12-23 10:23:33(格式和datetiime一样)

year:1978

》范围:一般每个格式都是有自己能表示的范围的,但是一般我们不去考虑,足够用

》插入记录的时候用引号表示

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 年某时)
时间类型的格式和范围

》datetime和timestamp的区别:

在实际应用的很多场景中,MySQL的这两种日期类型都能够满足我们的需要,存储精度都为秒,但在某些情况下,会展现出他们各自的优劣。下面就来总结一下两种日期类型的区别。

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语句中没有指定该列的更新值,则默认更新为当前时间。

datetime与timestamp的区别
timestamp和datetime的区别

 

 

 

3、字符串类型:

(1)分类:

》char:定长,浪费空间,存取速度快

》varchar:变长,精准,节省空间,但是存取速度慢

(2)范围:

》char是0-255    varchar是0-21844

(3)宽度的限制:指定的宽度是字符个数,超出宽度的字符会丢弃,只会保留指定宽度的部分

》》》》》注意:char始终都是定长,不管有多少始终都是指定的宽度,所以存储速度快,不够的会用空格填充;varchar存储是会在字符串数据前做标记,标记就是

》》》》》记录数据的字节数,这样取得时候才好取,标记一般是1-2个字节

(4)验证定长和变长

》》mysql在取字符串数据的时候会自动把填充的空格删掉,所以要想看真正的效果就必须设置

》》SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';这样就不会把空格去掉

》》看存储的长度要用到length()和char_length()函数,前者是查看字节长度,后者是查看字符个数的

》》查看字节长度select length(*) from table1

》》查看字符个数select char_length(*) from table1

#官网:https://dev.mysql.com/doc/refman/5.7/en/char.html
#注意:char和varchar括号内的参数指的都是字符的长度

#char类型:定长,简单粗暴,浪费空间,存取速度快
    字符长度范围:0-255(一个中文是一个字符,是utf8编码的3个字节)
    存储:
        存储char类型的值时,会往右填充空格来满足长度
        例如:指定长度为10,存>10个字符则报错,存<10个字符则用空格填充直到凑够10个字符存储

    检索:
        在检索或者说查询时,查出的结果会自动删除尾部的空格,除非我们打开pad_char_to_full_length SQL模式(SET sql_mode = 'PAD_CHAR_TO_FULL_LENGTH';)

#varchar类型:变长,精准,节省空间,存取速度慢
    字符长度范围:0-65535(如果大于21845会提示用其他类型 。mysql行最大限制为65535字节,字符编码为utf-8:https://dev.mysql.com/doc/refman/5.7/en/column-count-limit.html)
    存储:
        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)
    
    检索:
        尾部有空格会保存下来,在检索或者说查询时,也会正常显示包含空格在内的内容

 

 

4、枚举类型和集合类型

(1)枚举类型enum:适合应用在像性别这样的字段,增加表时可以写多个值,有固定值,并且每次只能取一个值,也就是增加记录时只能传一个值,因为一个人只能有一个性别

(2)集合类型set:适合应用在像爱好这样的字段,增加表时也可以写多个值,并且每次可以取多个值,也就是增加记录时可以传多个值,因为一个人可能有多个爱好,注意传的时候用'a,b,c'这样字符串的形式去传

 

 

二、约束条件

1、已经学过的约束条件:

》not null  不能为空,即不能传空值

》auto_increment  自增

补充:

#####也可以创建表时指定auto_increment的初始值,注意初始值的设置为表选项,应该放到括号外

create table student(
  id int primary key auto_increment,

  name varchar(20),

  sex enum('male','female') default 'male'

  )auto_increment=3;

 

》default  设置默认值,有默认值的字段无论是null(默认可以传空)还是not null(不能为空),都可以传入空,插入空的时候字段值就是默认值

》unsigned  设置为无符号

》zerofill 用0填充空余位

2、key

》unique  要求字段值是唯一的

》primary key 主键,要求字段值不为空且唯一,一个表不是必须要有主键的

注意:

——>实现效果和not null unique一样的

——>除了在数据类型后写约束条件,还可以用constraint pk_name primary key(id) pk_name自己设置的名字;或者直接primary key(ip,port);来写约束条件

——>若给多个字段设置了not null unique,mysql会默认把第一个字段设置为主键即primary key,其它仍是not null unique,若只有一个字段设为not null unique则会把这个字段设为主键

——>一个表只能设置一次主键,但可以有多个not null unique,意思就是可以把一个字段设为主键,也可以把多个字段组合起来设为主键(利用primary key(ip,port)这样的形式),但是永远只能设置一次

 

posted @ 2017-10-23 14:02  九二零  阅读(136)  评论(0编辑  收藏  举报