MySQL数据库数据类型之枚举类型ENUM测试总结
【导读】
MySQL数据库提供针对字符串存储的一种特殊数据类型:枚举类型ENUM,这种数据类型可以给予我们更多提高性能、降低存储容量和降低程序代码理解的技巧,前面介绍了首先介绍了四种数据类型的特性总结,其后又分别介绍了布尔类型BOOL或称布尔类型BOOLEAN,以及后续会再单独介绍集合类型SET,本文我们详细介绍集合类型enum测试过程与总结,加深对mysql数据库集合类型enum的理解记忆。
n 枚举类型ENUM
a).数据库表mysqlops_enum结构
执行数据库表mysqlops_enum创建的SQL语句:
1 2 3 4 5 6 7 8 9 10 11 | root@localhost : test 11:22:29> CREATE TABLE Mysqlops_enum(ID INT NOT NULL AUTO_INCREMENT, -> Job_type ENUM( 'DBA' , 'SA' , 'Coding Engineer' , 'JavaScript' , 'NA' , 'QA' , '' , 'other' ) NOT NULL , -> Work_City ENUM( 'shanghai' , 'beijing' , 'hangzhou' , 'shenzhen' , 'guangzhou' , 'other' ) NOT NULL DEFAULT 'shanghai' , -> PRIMARY KEY (ID) -> )ENGINE=InnoDB CHARACTER SET 'utf8' COLLATE 'utf8_general_ci' ; Query OK, 0 rows affected (0.00 sec) |
执行查询数据库表mysqlops_enum结构的SQL语句:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | root@localhost : test 11:23:31> SHOW CREATE TABLE Mysqlops_enum\\G *************************** 1. row *************************** Table : Mysqlops_enum Create Table : CREATE TABLE `Mysqlops_enum` ( `ID` int (11) NOT NULL AUTO_INCREMENT, `Job_type` enum( 'DBA' , 'SA' , 'Coding Engineer' , 'JavaScript' , 'NA' , 'QA' , '' , 'other' ) NOT NULL , `Work_City` enum( 'shanghai' , 'beijing' , 'hangzhou' , 'shenzhen' , 'guangzhou' , 'other' ) NOT NULL DEFAULT 'shanghai' , PRIMARY KEY (`ID`) ) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8 1 row in set (0.00 sec) |
小结:
为方便测试枚举类型,如何处理字段定义的默认值、是否允许为NULL和空值的情况,我们定义了2个枚举类型的字段名,经过对比创建与查询数据库中表的结构信息,没有发现MySQL数据库默认修改任何信息。
b). 写入不同类型的测试数据
写入一条符合枚举类型定义的记录值:
1 2 3 | root@localhost : test 11:22:35> INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES (1, 'QA' , 'shanghai' ); Query OK, 1 row affected (0.00 sec) |
测试第二个枚举类型字Work_City是否允许为空记录值:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | root@localhost : test 11:22:42> INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES (2, 'NA' , '' ); Query OK, 1 row affected, 1 warning (0.00 sec) root@localhost : test 11:22:48> SHOW WARNINGS; + ---------+------+------------------------------------------------+ | Level | Code | Message | + ---------+------+------------------------------------------------+ | Warning | 1265 | Data truncated for column 'Work_City' at row 1 | + ---------+------+------------------------------------------------+ 1 row in set (0.00 sec) |
测试第二个枚举类型字段Work_City是否允许存储NULL值:
1 2 3 | root@localhost : test 11:22:53> INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES (3, 'Other' , NULL ); ERROR 1048 (23000): Column 'Work_City' cannot be null |
测试第一个枚举类型字段Job_type是否可以存储空白值:
1 2 3 | root@localhost : test 11:22:59> INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES (4, '' , 'hangzhou' ); Query OK, 1 row affected (0.00 sec) |
测试第二个枚举类型字段Job_City如何处理没有在定义中描述的值域第一个枚举类型字段Work_Type的默认值没指定情况下,会默认填写那个值:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | root@localhost : test 11:23:06> INSERT INTO Mysqlops_enum(ID,Work_City) VALUES (5, 'ningbo' ); Query OK, 1 row affected, 1 warning (0.00 sec) root@localhost : test 11:23:13> SHOW WARNINGS; + ---------+------+------------------------------------------------+ | Level | Code | Message | + ---------+------+------------------------------------------------+ | Warning | 1265 | Data truncated for column 'Work_City' at row 1 | + ---------+------+------------------------------------------------+ 1 row in set (0.00 sec) |
测试第二个枚举类型字段未插入数据的情况下,是否能使用上字段定义中指定的默认值:
1 2 3 | root@localhost : test 11:23:17> INSERT INTO Mysqlops_enum(ID,Job_type) VALUES (6, 'DBA' ); Query OK, 1 row affected (0.00 sec) |
小结:
c). 查询数据库表mysqlops_enum的数据
查询枚举类型数据库表Mysqlops_enum所有的数据(注释:两个枚举类型字段都是非NULL,所以截断后的值为空格):
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | root@localhost : test 11:23:24> SELECT * FROM Mysqlops_enum; + ----+----------+-----------+ | ID | Job_type | Work_City | + ----+----------+-----------+ | 1 | QA | shanghai | | 2 | NA | | | 4 | | hangzhou | | 5 | DBA | | | 6 | DBA | shanghai | + ----+----------+-----------+ 5 rows in set (0.00 sec) |
验证枚举类型字段存储的是数据对应的序列编号,而不是真实的字符串值,且序列号是与枚举类型字段值域列表中的顺序有关:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 | root@localhost : test 11:23:57> SELECT * FROM Mysqlops_enum WHERE Work_City=0; + ----+----------+-----------+ | ID | Job_type | Work_City | + ----+----------+-----------+ | 2 | NA | | | 5 | DBA | | + ----+----------+-----------+ 2 rows in set (0.00 sec) root@localhost : test 01:22:08> SELECT * FROM Mysqlops_enum WHERE Work_City=1; + ----+----------+-----------+ | ID | Job_type | Work_City | + ----+----------+-----------+ | 1 | QA | shanghai | | 6 | DBA | shanghai | + ----+----------+-----------+ 2 rows in set (0.00 sec) root@localhost : test 02:40:31> SELECT * FROM Mysqlops_enum WHERE Work_City=2; Empty set (0.00 sec) root@localhost : test 02:40:33> SELECT * FROM Mysqlops_enum WHERE Work_City=3; + ----+----------+-----------+ | ID | Job_type | Work_City | + ----+----------+-----------+ | 4 | | hangzhou | + ----+----------+-----------+ 1 row in set (0.01 sec) root@localhost : test 02:40:34> SELECT * FROM Mysqlops_enum WHERE Work_City=4; Empty set (0.00 sec) root@localhost : test 02:40:36> SELECT * FROM Mysqlops_enum WHERE Work_City=5; Empty set (0.00 sec) root@localhost : test 02:40:37> SELECT * FROM Mysqlops_enum WHERE Work_City=6; Empty set (0.00 sec) root@localhost : test 04:29:07> SELECT * FROM Mysqlops_enum WHERE Job_type=7; + ----+----------+-----------+ | ID | Job_type | Work_City | + ----+----------+-----------+ | 4 | | hangzhou | + ----+----------+-----------+ 1 row in set (0.00 sec) |
枚举类型数据小结:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 | root@localhost : test 04:37:32> SELECT * FROM Mysqlops_enum WHERE Job_type=0; + ----+----------+-----------+ | ID | Job_type | Work_City | + ----+----------+-----------+ | 8 | | hangzhou | + ----+----------+-----------+ 1 row in set (0.00 sec) root@localhost : test 04:37:35> SELECT * FROM Mysqlops_enum WHERE Job_type= '' ; + ----+----------+-----------+ | ID | Job_type | Work_City | + ----+----------+-----------+ | 4 | | hangzhou | | 8 | | hangzhou | + ----+----------+-----------+ 2 rows in set (0.00 sec) |
数据类型系列讲解文章列表:
MySQL数据库数据类型之ENUM、SET、BOOL/BOOLEAN、TINYINT
MySQL数据库之数据类型BOOL/BOOLEAN与TINYINT测试总结
建议继续学习:
- MySQL数据库之布尔类型、枚举类型和集合类型的应用场景详解 (阅读:5660)
- MySQL数据库中的5种数据类型简介 (阅读:4359)
- MySQL数据库之枚举数据类型ENUM的DDL变更测试 (阅读:3883)
- MySQL数据库数据类型之ENUM、SET、BOOL/BOOLEAN、TINYINT (阅读:2941)
- PHP中的数据类型 (阅读:2452)
- Java数据类型和MySql数据类型对应表 (阅读:2259)
- 再谈JavaScript的数据类型问题 (阅读:2170)
- 用 JS 枚举质数 (阅读:2037)
- MySQL数据库之数据类型集合类型和枚举类型测试环境 (阅读:2091)
- java enum枚举类型用法小结 (阅读:2324)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:Eugene 来源: MySQLOPS 数据库与运维自动化技术分享
- 标签: ENUM 数据类型 枚举
- 发布时间:2012-03-26 22:20:06
-
[61] memory prefetch浅析
-
[57] find命令的一点注意事项
-
[33] 读书笔记-壹百度:百度十年千倍的29条法则
-
[32] Oracle bbed工具的编译
-
[30] 基本排序算法的PHP实现
-
[28] 卡诺模型―设计品质与设计价值的思考
-
[27] 小屏幕移动设备网页设计注意事项
-
[24] 8大实用又重要Mac使用技巧
-
[24] 程序员技术练级攻略
-
[20] 杨建:网站加速--Cache为王篇