首頁 > 資料庫 > mysql教程 > 為什麼我們不應該將數字儲存到 MySQL ENUM 欄位中?

為什麼我們不應該將數字儲存到 MySQL ENUM 欄位中?

WBOY
發布: 2023-09-04 12:29:09
轉載
1274 人瀏覽過

为什么我们不应该将数字存储到 MySQL ENUM 列中?

MySQL將ENUM值內部儲存為整數鍵(索引號),以引用ENUM成員。不將整數值儲存在ENUM列中的主要原因是明顯地MySQL最終引用索引而不是值,反之亦然。

範例

以下範例可以闡明:

mysql> Create table enmtest(Val ENUM('0','1','2'));
Query OK, 0 rows affected (0.18 sec)

mysql> Insert into enmtest values('1'),(1);
Query OK, 2 rows affected (0.19 sec)
Records: 2 Duplicates: 0 Warnings: 0

mysql> Select * from enmtest;
+-----+
| Val |
+-----+
| 1   |
| 0   |
+-----+
2 rows in set (0.00 sec)
登入後複製

在這裡,我們將'1'作為字串插入,不小心還插入了一個沒有引號的數字1。 MySQL混淆地使用我們的數位輸入作為索引值,也就是對成員清單中的第一項的內部引用(即0)。

以上是為什麼我們不應該將數字儲存到 MySQL ENUM 欄位中?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:tutorialspoint.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板