首页 > 代码库 > MySQL数据类型--------枚举与集合类型实战
MySQL数据类型--------枚举与集合类型实战
1. 背景
* MySQL数据库提供针对字符串存储的两种特殊数据类型:枚举类型ENUM和集合类型SET,集合类型数据类型可以给予我们更多提高性能、降低存储容量和降低程序代码理解的技巧。
2. 枚举与集合类型所属空间与最大成员数量
类型 | 占用字节 | 最大成员数量 |
ENUM | 1 or 2, 取决于枚举成员的数量 | 65535 |
SET | 1|2|3|4|8,取决于集合成员的数量 | 64 |
3. 枚举与集合约束检查应用
* 创建表 e_s
mysql> CREATE TABLE e_s( -> uid BIGINT PRIMARY KEY NOT NULL AUTO_INCREMENT, -> sex ENUM(‘male‘, ‘female‘) NOT NULL -> )ENGINE=INNODB CHARSET=utf8mb4; Query OK, 0 rows affected (0.06 sec)
* 清空约束检查SQL_MODE
mysql> set sql_mode=‘‘; Query OK, 0 rows affected (0.01 sec)
* 插入正常数据 [ 值在枚举成员中 ]
mysql> INSERT INTO e_s SELECT null, ‘male‘; Query OK, 1 row affected (0.03 sec) Records: 1 Duplicates: 0 Warnings: 0
* 插入非正常数据 [ 值不在枚举成员中 ] [只是警告]
mysql> INSERT INTO e_s SELECT null, ‘males‘; Query OK, 1 row affected, 1 warning (0.03 sec) Records: 1 Duplicates: 0 Warnings: 1
* 查看插入非正常数据的warning
mysql> SHOW WARNINGS; +---------+------+------------------------------------------+ | Level | Code | Message | +---------+------+------------------------------------------+ | Warning | 1265 | Data truncated for column ‘sex‘ at row 1 | +---------+------+------------------------------------------+ 1 row in set (0.00 sec)
* 查看 e_s 表所有数据 [ 非法插入的ENUM列会显示为空 ]
mysql> SELECT * FROM e_s; +-----+------+ | uid | sex | +-----+------+ | 1 | male | | 3 | | +-----+------+ 2 rows in set (0.01 sec)
* 设置SQL_MODE 约束检查
mysql> SET sql_mode = ‘STRICT_TRANS_TABLES‘; Query OK, 0 rows affected (0.00 sec)
* 插入非正常数据 [ 值不在枚举成员中 ] [ 报错返回 ]
mysql> INSERT INTO e_s SELECT null, ‘males‘; ERROR 1265 (01000): Data truncated for column ‘sex‘ at row 1
4. 总结
以需求驱动技术,技术本身没有优略之分,只有业务之分。
本文出自 “sea” 博客,请务必保留此出处http://lisea.blog.51cto.com/5491873/1943296
MySQL数据类型--------枚举与集合类型实战
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。