天天看點

java 枚舉類型enum用法_MySQL資料類型測試:枚舉類型ENUM測試資料總結(第六節)...

java 枚舉類型enum用法_MySQL資料類型測試:枚舉類型ENUM測試資料總結(第六節)...

MySQL資料庫提供針對字元串存儲的一種特殊資料類型:枚舉類型ENUM,這種資料類型可以給予我們更多提高性能、降低存儲容量和降低程式代碼了解的技巧,前面幾篇文章首先介紹了四種資料類型的特性總結,其後又分别介紹了布爾類型BOOL或稱布爾類型BOOLEAN,以及後續會再單獨介紹集合類型SET,本文我們詳細介紹集合類型enum測試過程與總結,加深對mysql資料庫集合類型enum的了解記憶。

枚舉類型ENUM

a).資料庫表mysqlops_enum結構

執行資料庫表mysqlops_enum建立的SQL語句:

[email protected] : 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語句:

[email protected] : test 11:23:31> SHOW CREATE TABLE Mysqlops_enumG
*************************** 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). 寫入不同類型的測試資料

寫入一條符合枚舉類型定義的記錄值:

[email protected] : 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是否允許為空記錄值:

[email protected] : 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)

[email protected] : 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值:

[email protected] : 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是否可以存儲空白值:

[email protected] : 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的預設值沒指定情況下,會預設填寫那個值:

[email protected] : test 11:23:06> INSERT INTO Mysqlops_enum(ID,Work_City) VALUES(5,‘ningbo’);
Query OK, 1 row affected, 1 warning (0.00 sec)

[email protected] : 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)
           

測試第二個枚舉類型字段未插入資料的情況下,是否能使用上字段定義中指定的預設值:

[email protected] : test 11:23:17> INSERT INTO Mysqlops_enum(ID,Job_type) VALUES(6,‘DBA’);
Query OK, 1 row affected (0.00 sec)
           

小結:

I.若是枚舉類型字段定義為非NULL,預設的SQL_MODE模式下,插入NULL值則會報錯,導緻SQL語句執行失敗;若是沒有明确申明非NULL,則允許插入NULL值;

II.若是枚舉類型字段的枚舉值中,沒有指定空格字元值,插入空格字元資料時,會出現資料截斷的警告資訊,但是SQL語句依然執行成功;

III.若是向枚舉類型字段插入未在定義清單中出現的資料,則會出現資料截斷的警告資訊,但是SQL語句依然執行成功;

IV.若是枚舉類型定義為非NULL,向資料庫表中插入新資料,但未指定枚舉類型字段的值,則使用枚舉類型字段定義申明的預設值,若是無顯示申明則是采用枚舉類型字段的枚舉清單中第一個值作為預設值;

c). 查詢資料庫表mysqlops_enum的資料

查詢枚舉類型資料庫表Mysqlops_enum所有的資料(注釋:兩個枚舉類型字段都是非NULL,是以截斷後的值為空格):

[email protected] : 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)
           

驗證枚舉類型字段存儲的是資料對應的序列編号,而不是真實的字元串值,且序列号是與枚舉類型字段值域清單中的順序有關:

[email protected] : 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)
[email protected] : 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)

[email protected] : test 02:40:31> SELECT * FROM Mysqlops_enum WHERE Work_City=2;
Empty set (0.00 sec)

[email protected] : 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)

[email protected] : test 02:40:34> SELECT * FROM Mysqlops_enum WHERE Work_City=4;
Empty set (0.00 sec)

[email protected] : test 02:40:36> SELECT * FROM Mysqlops_enum WHERE Work_City=5;
Empty set (0.00 sec)

[email protected] : test 02:40:37> SELECT * FROM Mysqlops_enum WHERE Work_City=6;
Empty set (0.00 sec)
[email protected] : 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)
           

枚舉類型資料小結:

I.枚舉類型字段定義必須為确定的值,不能為變量、函數、表達式等;

II.若是向枚舉類型字段插入NULL值,且枚舉類型的字段定義為非NULL,SQL語句會執行失敗;

III.若是向枚舉類型字段插入,其枚舉清單值域中不存在的值,則會發生字段值的截斷,并且用空格字元串值替代,其存儲的序列編号為0;

IV.若是枚舉類型字段定義的枚舉清單值域中存在空字元串值,該枚舉類型字段發生字段值截斷,則是會用空格值替代,但是其存儲的序列号與枚舉清單中存儲的序列号不同,也即參考事例所示:

[email protected] : 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)

[email protected] : 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)
           

V.若是枚舉類型字段定義為非NULL,且沒有為該字段指定值的方式插入資料行,則把字段定義顯式申明的預設值作為字段預設值,沒有顯式申明則把枚舉列值域表中第一個值作為預設值;

VI.若是枚舉類型字段允許插入NULL值,則NULL值對應存儲的序列号為NULL。

---------------------

以上就是今天的文章内容,有什麼疑問也可以直接評論留言哦~如果這篇文章有幫助到你的話别忘了給我點個贊哦~我們下篇文章再見~

作者:Amy—go