1. 程式人生 > >MySQL數據類型--------枚舉與集合類型實戰

MySQL數據類型--------枚舉與集合類型實戰

mysql dba 數據類型

1. 背景

  * MySQL數據庫提供針對字符串存儲的兩種特殊數據類型:枚舉類型ENUM和集合類型SET,集合類型數據類型可以給予我們更多提高性能、降低存儲容量和降低程序代碼理解的技巧。


2. 枚舉與集合類型所屬空間與最大成員數量

類型占用字節
最大成員數量
ENUM1 or 2, 取決於枚舉成員的數量65535
SET1|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數據類型--------枚舉與集合類型實戰