1. 背景
* MySQL数据库提供针对字符串存储的两种特殊数据类型:枚举类型ENUM和集合类型SET,集合类型数据类型可以给予我们更多提高性能、降低存储容量和降低程序代码理解的技巧。
2. 枚举与集合类型所属空间与最大成员数量
| 类型 | 占用字节 |
最大成员数量 |
| ENUM | 1 or 2, 取决于枚举成员的数量 | 65535 |
| SET | 1|2|3|4|8,取决于集合成员的数量 | 64 |
3. 枚举与集合约束检查应用
* 创建表 e_s
|
1
2
3
4
5
|
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
|
1
2
|
mysql>
set
sql_mode=
''
;
Query OK, 0 rows affected (0.01 sec)
|
* 插入正常数据 [ 值在枚举成员中 ]
|
1
2
3
|
mysql> INSERT INTO e_s SELECT null,
'male'
;
Query OK, 1 row affected (0.03 sec)
Records: 1 Duplicates: 0 Warnings: 0
|
* 插入非正常数据 [ 值不在枚举成员中 ] [只是警告]
|
1
2
3
|
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
|
1
2
3
4
5
6
7
|
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列会显示为空 ]
|
1
2
3
4
5
6
7
8
|
mysql> SELECT * FROM e_s;
+-----+------+
| uid | sex |
+-----+------+
| 1 | male |
| 3 | |
+-----+------+
2 rows
in
set
(0.01 sec)
|
* 设置SQL_MODE 约束检查
|
1
2
|
mysql> SET sql_mode =
'STRICT_TRANS_TABLES'
;
Query OK, 0 rows affected (0.00 sec)
|
* 插入非正常数据 [ 值不在枚举成员中 ] [ 报错返回 ]
|
1
2
|
mysql> INSERT INTO e_s SELECT null,
'males'
;
ERROR 1265 (01000): Data truncated
for
column
'sex'
at row 1
|
4. 总结
以需求驱动技术,技术本身没有优略之分,只有业务之分。
本文转自asd1123509133 51CTO博客,原文链接:http://blog.51cto.com/lisea/1943296,如需转载请自行联系原作者