robin 发表于 2018-9-29 10:00:34

MySQL数据类型--------枚举与集合类型实战

  1. 背景
  * MySQL数据库提供针对字符串存储的两种特殊数据类型:枚举类型ENUM和集合类型SET,集合类型数据类型可以给予我们更多提高性能、降低存储容量和降低程序代码理解的技巧。
  2. 枚举与集合类型所属空间与最大成员数量
  
类型占用字节最大成员数量ENUM1 or 2, 取决于枚举成员的数量65535SET1|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: 1Duplicates: 0Warnings: 0
  * 插入非正常数据 [ 值不在枚举成员中 ] [只是警告]
mysql> INSERT INTO e_s SELECT null, 'males';  
Query OK, 1 row affected, 1 warning (0.03 sec)
  
Records: 1Duplicates: 0Warnings: 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. 总结
  以需求驱动技术,技术本身没有优略之分,只有业务之分。


页: [1]
查看完整版本: MySQL数据类型--------枚举与集合类型实战