程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> 關於MYSQL數據庫 >> 細化解析:教你快速掌握 ENUM和SET約束

細化解析:教你快速掌握 ENUM和SET約束

編輯:關於MYSQL數據庫

ENUM和SET列提供了定義僅能包含給定值集合的列的有效方式。但是,從MySQL 5.0.2起,ENUM和SET不是實際約束。其原因與不重視NOT NULL的原因一樣。

ENUM列總有1個默認值。如果未指定默認值,對於包含NULL的列,默認值為NULL;否則,第1個枚舉值將被當作默認值。

 

如果在ENUM列中插入了不正確的值,或者,如果使用IGNORE將值強制插入了ENUM列,會將其設置為保留的枚舉值0,對於字符串情形,將顯示為空字符串。

 

如果在SET列中插入了不正確值,該值將被忽略。例如,如果列能包含值“a”、“b”和“c”,並賦值“a,x,b,y”,結果為“a,b”。

從5.0.2開始,可以對服務器進行配置,以使用嚴格的SQL模式。

啟用嚴格模式後,ENUM或SET列的定義可作為對輸入至列的值的約束。如果值不滿足下述條件,將出現錯誤:

· ENUM值必須是在列定義中給出的值之一,或內部的數字等同物。該值不能是錯誤值(即,0或空字符串)。對於定義為ENUM('a','b','c')的列,諸如''、'd'和'ax'等,均是非法的,並將被拒。

 

· SET值必須是空字符串,或由1個或多個在列定義中給出的且用逗號隔開的值組成。 對於定義為SET('a','b','c')的列,諸如'd'和'a,b,c,d'等,均是非法的,並將被拒。

 

如果使用了INSERT IGNORE或UPDATE IGNORE,在嚴格模式下,可抑制無效值導致的錯誤。在這種情況下,將生成警告而不是錯誤。對於ENUM,值將作為錯誤成員(0)插入。對於SET,會將給定值插入,但無效的子字符串將被刪除。例如,'a,x,b,y'的結果是'a,b',就像前面介紹的那樣。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved