top
Loading...
1.8.6.3.ENUM和SET約束
1.8.6.3. ENUM和SET約束

ENUMSET列提供了定義僅能包含給定值集合的列的有效方式。但是,從MySQL 5.0.2起,ENUMSET不是實際約束。其原因與不重視NOT NULL的原因一樣。請參見1.8.6.2節,“對無效數據的約束”。

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

如果在ENUM列中插入了不正確的值,或者,如果使用IGNORE將值強制插入了ENUM列,會將其設置為保留的枚舉值0,對于字符串情形,將顯示為空字符串。請參見11.4.4節,“ENUM類型”。

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

從5.0.2開始,可以對服務器進行配置,以使用嚴格的SQL模式。請參見5.3.2節,“SQL服務器模式”。啟用嚴格模式后,ENUMSET列的定義可作為對輸入至列的值的約束。如果值不滿足下述條件,將出現錯誤:

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

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

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

作者:mysql.com
來源:http://dev.mysql.com/doc/refman/5.1/zh/introduction.html
北斗有巢氏 有巢氏北斗