真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MySQL枚舉與集合類型的應(yīng)用-創(chuàng)新互聯(lián)

本文主要給大家介紹MySQL枚舉與集合類型的應(yīng)用,文章內(nèi)容都是筆者用心摘選和編輯的,具有一定的針對(duì)性,對(duì)大家的參考意義還是比較大的,下面跟筆者一起了解下MySQL枚舉與集合類型的應(yīng)用吧。

從網(wǎng)站建設(shè)到定制行業(yè)解決方案,為提供網(wǎng)站設(shè)計(jì)、網(wǎng)站制作服務(wù)體系,各種行業(yè)企業(yè)客戶提供網(wǎng)站建設(shè)解決方案,助力業(yè)務(wù)快速發(fā)展。創(chuàng)新互聯(lián)將不斷加快創(chuàng)新步伐,提供優(yōu)質(zhì)的建站服務(wù)。

1. 背景

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

2. 枚舉與集合類型所屬空間與大成員數(shù)量

類型占用字節(jié)
大成員數(shù)量
ENUM1 or 2, 取決于枚舉成員的數(shù)量65535
SET1|2|3|4|8,取決于集合成員的數(shù)量64

3. 枚舉與集合約束檢查應(yīng)用

  * 創(chuàng)建表 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)

  * 插入正常數(shù)據(jù) [ 值在枚舉成員中 ]

mysql> INSERT INTO e_s SELECT null, 'male';
Query OK, 1 row affected (0.03 sec)
Records: 1  Duplicates: 0  Warnings: 0

  * 插入非正常數(shù)據(jù) [ 值不在枚舉成員中 ] [只是警告]

mysql> INSERT INTO e_s SELECT null, 'males';
Query OK, 1 row affected, 1 warning (0.03 sec)
Records: 1  Duplicates: 0  Warnings: 1

  * 查看插入非正常數(shù)據(jù)的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 表所有數(shù)據(jù) [ 非法插入的ENUM列會(huì)顯示為空 ]

mysql> SELECT * FROM e_s;
+-----+------+
| uid | sex  |
+-----+------+
|   1 | male |
|   3 |      |
+-----+------+
2 rows in set (0.01 sec)

  * 設(shè)置SQL_MODE 約束檢查

mysql> SET sql_mode = 'STRICT_TRANS_TABLES';
Query OK, 0 rows affected (0.00 sec)

  * 插入非正常數(shù)據(jù) [ 值不在枚舉成員中 ] [ 報(bào)錯(cuò)返回 ]

mysql> INSERT INTO e_s SELECT null, 'males';
ERROR 1265 (01000): Data truncated for column 'sex' at row 1

4. 總結(jié)

以需求驅(qū)動(dòng)技術(shù),技術(shù)本身沒有優(yōu)略之分,只有業(yè)務(wù)之分。

看完以上關(guān)于MySQL枚舉與集合類型的應(yīng)用,很多讀者朋友肯定多少有一定的了解,如需獲取更多的行業(yè)知識(shí)信息 ,可以持續(xù)關(guān)注我們的行業(yè)資訊欄目的。

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。


網(wǎng)站名稱:MySQL枚舉與集合類型的應(yīng)用-創(chuàng)新互聯(lián)
URL分享:http://weahome.cn/article/gsoej.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部