MySQL数据库数据类型之枚举类型ENUM测试总结
【导读】
MySQL数据库提供针对字符串存储的一种特殊数据类型:枚举类型ENUM,这种数据类型可以给予我们更多提高性能、降低存储容量和降低程序代码理解的技巧,前面介绍了首先介绍了四种数据类型的特性总结,其后又分别介绍了布尔类型BOOL或称布尔类型BOOLEAN,以及后续会再单独介绍集合类型SET,本文我们详细介绍集合类型enum测试过程与总结,加深对mysql数据库集合类型enum的理解记忆。
n 枚举类型ENUM
a).数据库表mysqlops_enum结构
执行数据库表mysqlops_enum创建的SQL语句:
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语句:
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). 写入不同类型的测试数据
写入一条符合枚举类型定义的记录值:
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是否允许为空记录值:
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值:
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是否可以存储空白值:
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的默认值没指定情况下,会默认填写那个值:
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)
测试第二个枚举类型字段未插入数据的情况下,是否能使用上字段定义中指定的默认值:
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,所以截断后的值为空格):
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)
验证枚举类型字段存储的是数据对应的序列编号,而不是真实的字符串值,且序列号是与枚举类型字段值域列表中的顺序有关:
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)
枚举类型数据小结:
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数据库之布尔类型、枚举类型和集合类型的应用场景详解 (阅读:5615)
- MySQL数据库中的5种数据类型简介 (阅读:4310)
- MySQL数据库之枚举数据类型ENUM的DDL变更测试 (阅读:3820)
- MySQL数据库数据类型之ENUM、SET、BOOL/BOOLEAN、TINYINT (阅读:2877)
- PHP中的数据类型 (阅读:2408)
- Java数据类型和MySql数据类型对应表 (阅读:2228)
- 再谈JavaScript的数据类型问题 (阅读:2142)
- 用 JS 枚举质数 (阅读:2003)
- MySQL数据库之数据类型集合类型和枚举类型测试环境 (阅读:2045)
- java enum枚举类型用法小结 (阅读:2158)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:Eugene 来源: MySQLOPS 数据库与运维自动化技术分享
- 标签: ENUM 数据类型 枚举
- 发布时间:2012-03-26 22:20:06
- [56] WEB系统需要关注的一些点
- [52] Oracle MTS模式下 进程地址与会话信
- [49] find命令的一点注意事项
- [48] 如何拿下简短的域名
- [48] Go Reflect 性能
- [47] Twitter/微博客的学习摘要
- [47] 图书馆的世界纪录
- [46] android 开发入门
- [46] IOS安全–浅谈关于IOS加固的几种方法
- [45] 流程管理与用户研究