MySQL数据类型set和enum

MySQL数据类型set和enum


目录
1 MYSQL数据类型set和enum 1
1.1 SET和ENUM类型 1


1 MySQL数据类型set和enum
1.1 Set和Enum类型
1. Set类型:集合,列可赋予多个集合成员。其值来自创建表时规定的允许的串集中选择,可包括串集中任意或所有成员,每个值成员之间以逗号隔开。

2. Enum类型:枚举,列可赋予某个枚举成员。其值来自创建表时规定的允许的枚举中选择,只能选择其中之一。

3.3. Set和Enum的SQL操作
创建Set和Enum
CREATE TABLE `test` (
`Id` int(11) NOT NULL AUTO_INCREMENT,
`myset` set('a','b','c') DEFAULT '',
`myenum` enum('a','b','c') DEFAULT NULL,
PRIMARY KEY (`Id`)
)
插入Set和Enum
INSERT INTO `test` VALUES (1,'a,b','a');
INSERT INTO `test` VALUES (2,'b,a,b','b');
SELECT * from test
Id Myset Myenum
1 a,b a
2 a,b b
说明:集合中可去除重复的值。
通过find_in_set()函数或like操作查取Set值。
select * from test where FIND_IN_SET('a',myset)
select * from test where myset like '%a%'

4. Set和Enum的存储大小
Set:集合最多可以有64个不同的成员。Set最多可以存储8个字节。Set列的存储大小由集合成员数目决定,对于集合成员数目为1到8,9到16,17到24,25到32,33到64的成员集合,其Set值分别站用1,2,3,4或8个字节。
Enum:枚举可具有最多65536 个成员。最多可以存储2个字节。枚举值的数目决定了Enum列的存储大小,一个字节可以存储256个值,两个字节可以存储65536个值,存储时一个字节还是两个字节依赖于枚举成员数是否大于256个。

5. Set和Enum的排序顺序
Set和Enum在定义中的值顺序决定了排序顺序,Enum定义中的值顺序就是Enum中值排序顺序,但Set中排序顺序更为复杂,因为列值可以包含多个集合成员。
Set和Enum被归为串类型是由于在建立这些类型的列时,枚举和集合成员被指定为串。但是,这些成员在内部存放时作为数值,而且同样可作为数值来处理。这表示ENUM 和S E T类型比其他的串类型更为有效,因为通常可用数值运算而不是串运算来处理它们。而且这还表示ENUM 和SET 值可用在串或数值的环境中。
select myset, myset+0 from test
Myset Myset+0
a 1
b 2
a,b 3

6. Set和Enum的缺省值
对于SET 类型,在相应的列不能包含NULL 时其缺省值实际上是空集,不过这里空集等价于空串
对于Enum类型,如果将ENUM列声明为允许NULL,NULL值则为该列的一个有效值,并且默认值为NULL。如果ENUM列被声明为NOT NULL,其默认值为允许的值列的第1个元素。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值