mysql中的set和enum类型的用法和区别
mysql中的enum和set其实都是string类型的而且只能在指定的集合里取值, 不同的是set可以取多个值,enum只能取一个值。
值 索引值NULLNULL""0"one"1"two"2"three"3测试时发现''时,用0来表示查不到数据。
换个枚举最大可以有 65535 个成员值。
从 MySQL 3.23.51 开始,当表被创建时,
ENUM值尾部的空格将会自动删除。当为一个
ENUM列赋值时,字母的大小写是无关紧要的。然而,以后从列中检索出来的值的大小写却是匹配于创建表时所指定的允许值。如果在一个数字语境中检索一个
ENUM,列值的索引值将被返回。例如,你可以像这样使用数字值检索一个ENUM列:mysql> SELECT enum_col+0 FROM tbl_name;如果将一个数字存储到一个
ENUM中,数字被当作为一个索引值,并且存储的值是该索引值所对应的枚举成员。(但是,这在LOAD DATA将不能工作,因为它视所有的输入均为字符串。) 在一个ENUM字符串中存储数字是不明智的,因为它可能会打乱思维。
ENUM值依照列规格说明中的列表顺序进行排序。(换句话说,ENUM值依照它们的索引号排序。)举例来说,对于ENUM("a", "b")"a"排在"b"后,但是对于ENUM("b", "a"),"b"却排在"a"之前。空字符串排在非空字符串前,NULL值排在其它所有的枚举值前。为了防止意想不到的结果,建议依照字母的顺序定义ENUM列表。也可以通过使用GROUP BY CONCAT(col)来确定该以字母顺序排序而不是以索引值。如果希望得到一个
ENUM列的所有可能值,可以使用SHOW COLUMNS FROM table_name LIKE enum_colum