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 列中?的詳細內容,更多請關注www.92cms.cn其它相關文章!