|
枚举类型ENUM
a).数据库表mysqlops_enum结构
执行数据库表mysqlops_enum创建的SQL语句:
- <p>root@localhost : test 11:22:29> CREATE TABLE Mysqlops_enum(ID INT NOT NULL AUTO_INCREMENT,</p><p>-> Job_type ENUM(‘DBA’,‘SA’,‘Coding Engineer’,‘JavaScript’,‘NA’,‘QA’,’’,‘other’) NOT NULL,</p><p>-> Work_City ENUM(‘shanghai’,‘beijing’,‘hangzhou’,‘shenzhen’,‘guangzhou’,‘other’) NOT NULL DEFAULT ‘shanghai’,</p><p>-> PRIMARY KEY(ID)</p><p>-> )ENGINE=InnoDB CHARACTER SET ‘utf8’ COLLATE ‘utf8_general_ci’;</p><p>Query OK, 0 rows affected (0.00 sec)</p><p>执行查询数据库表Mysqlops_enum结构的SQL语句:</p><p>root@localhost : test 11:23:31> SHOW CREATE TABLE Mysqlops_enum\G</p><p>*************************** 1. row ***************************</p><p>Table: Mysqlops_enum</p><p>Create Table: CREATE TABLE Mysqlops_enum (</p><p>ID int(11) NOT NULL AUTO_INCREMENT,</p><p>Job_type enum(‘DBA’,‘SA’,‘Coding Engineer’,‘JavaScript’,‘NA’,‘QA’,’’,‘other’) NOT NULL,</p><p>Work_City enum(‘shanghai’,‘beijing’,‘hangzhou’,‘shenzhen’,‘guangzhou’,‘other’) NOT NULL DEFAULT ‘shanghai’,</p><p>PRIMARY KEY (ID)</p><p>) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8</p><p>1 row in set (0.00 sec)</p>
复制代码
小结:
为方便测试枚举类型,如何处理字段定义的默认值、是否允许为NULL和空值的情况,我们定义了2个枚举类型的字段名,经过对比创建与查询数据库中表的结构信息,没有发现MySQL数据库默认修改任何信息。
---------------------
b). 写入不同类型的测试数据
写入一条符合枚举类型定义的记录值:
- <p>root@localhost : test 11:22:35> INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES(1,‘QA’,‘shanghai’);</p><p>Query OK, 1 row affected (0.00 sec)</p>
复制代码
测试第二个枚举类型字Work_City是否允许为空记录值:
- <p>root@localhost : test 11:22:42> INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES(2,‘NA’,’’);</p><p>Query OK, 1 row affected, 1 warning (0.00 sec)</p><p>
- </p><p>root@localhost : test 11:22:48> SHOW WARNINGS;</p><p>±--------±-----±-----------------------------------------------+</p><p>| Level | Code | Message |</p><p>±--------±-----±-----------------------------------------------+</p><p>| Warning | 1265 | Data truncated for column ‘Work_City’ at row 1 |</p><p>±--------±-----±-----------------------------------------------+</p><p>1 row in set (0.00 sec)</p>
复制代码
测试第二个枚举类型字段Work_City是否允许存储NULL值:
- <p>root@localhost : test 11:22:53> INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES(3,‘Other’,NULL);</p><p>ERROR 1048 (23000): Column ‘Work_City’ cannot be null</p>
复制代码
测试第一个枚举类型字段Job_type是否可以存储空白值:
- <p>root@localhost : test 11:22:59> INSERT INTO Mysqlops_enum(ID,Job_type,Work_City) VALUES(4,’’,‘hangzhou’);</p><p>Query OK, 1 row affected (0.00 sec)</p>
复制代码
测试第二个枚举类型字段Job_City如何处理没有在定义中描述的值域第一个枚举类型字段Work_Type的默认值没指定情况下,会默认填写那个值:
- <p>root@localhost : test 11:23:06> INSERT INTO Mysqlops_enum(ID,Work_City) VALUES(5,‘ningbo’);</p><p>Query OK, 1 row affected, 1 warning (0.00 sec)</p><p>
- </p><p>root@localhost : test 11:23:13> SHOW WARNINGS;</p><p>±--------±-----±-----------------------------------------------+</p><p>| Level | Code | Message |</p><p>±--------±-----±-----------------------------------------------+</p><p>| Warning | 1265 | Data truncated for column ‘Work_City’ at row 1 |</p><p>±--------±-----±-----------------------------------------------+</p><p>1 row in set (0.00 sec)</p>
复制代码
测试第二个枚举类型字段未插入数据的情况下,是否能使用上字段定义中指定的默认值:
- <p>root@localhost : test 11:23:17> INSERT INTO Mysqlops_enum(ID,Job_type) VALUES(6,‘DBA’);</p><p>Query OK, 1 row affected (0.00 sec)</p>
复制代码
小结:
I.若是枚举类型字段定义为非NULL,默认的SQL_MODE模式下,插入NULL值则会报错,导致SQL语句执行失败;若是没有明确申明非NULL,则允许插入NULL值;
II.若是枚举类型字段的枚举值中,没有指定空格字符值,插入空格字符数据时,会出现数据截断的警告信息,但是SQL语句依然执行成功;
III.若是向枚举类型字段插入未在定义列表中出现的数据,则会出现数据截断的警告信息,但是SQL语句依然执行成功;
IV.若是枚举类型定义为非NULL,向数据库表中插入新数据,但未指定枚举类型字段的值,则使用枚举类型字段定义申明的默认值,若是无显示申明则是采用枚举类型字段的枚举列表中第一个值作为默认值;
|
|