尚硅谷之MySQL基础
8、枚举(ENUM)
MySql中的ENUM是一个字符串对象,其值来自表创建时在列规定中显式枚举的一列值:
- 可以插入空字符串""和NULL(如果运行NULL的话)。
- 如果你将一个非法值插入ENUM(也就是说,允许的值列之外的字符串),如果是严格模式,将不能插入,如果是非严格模式,将选用第一个元素代替,并警告。
- ENUM最多可以有65,535个成员,需要2个字节存储。
- 当创建表时,ENUM成员值的尾部空格将自动被删除。
值的索引规则如下:
- 来自列规定的允许的值列中的值从1开始编号。
- 空字符串错误值的索引值是0。
- NULL值的索引是NULL。
9、集合(SET)
SET和ENUM类型非常类似,也是一个字符串对象,里面包含0~64个成员。
SET和ENUM存储上有所不同,SET是根据成员的个数决定存储的字节数。
SET和ENUM最主要的区别在于SET类型一次可以选择多个成员,而ENUM则只能选择一个。
10、特殊的NULL类型
lNull类型特征:
(1)所有的类型的值都可以是null,包括int、float等数据类型
(2)空字符串””,不等于null,0也不等于null,false也不等于null
(3)任何运算符,判断符碰到NULL,都得NULL
(4)NULL的判断只能用is null,is not null
(5)NULL 影响查询速度,一般避免使值为NULL
面试:
为什么建表时,加not null default '' / default 0
答:不想让表中出现null值.
为什么不想要的null的值
答:(1)不好比较,null是一种类型,比较时,只能用专门的is null 和 is not null来比较.
碰到运算符,一律返回null
(2)效率不高,影响提高索引效果.
因此,我们往往,在建表时 not null default ''/0