温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

MySQL数据库中ENUM类型的作用是什么

发布时间:2021-08-04 16:49:06 来源:亿速云 阅读:183 作者:Leah 栏目:数据库

本篇文章给大家分享的是有关MySQL数据库中ENUM类型的作用是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。

  MySQL数据库中ENUM类型是什么意思

  ENUM类型是一个字符串对象,其值通常选自一个允许值列表中,该列表在表创建时的列规格说明中被明确地列举。

  在下列某些情况下,值也可以是空串("")或NULL。

  如果将一个无效值插入一个ENUM(即,一个不在允许值列表中的字符串),空字符串将作为一个特殊的错误值被插入。事实上,这个字符串有别于一个"普通的"空字符串,因为这个字符串有个数字索引值为0。稍后有更详细描述。

  如果一个ENUM被声明为NULL,NULL也是该列的一个合法值,并且该列的缺省值也将为NULL。如果一个ENUM被声明为NOTNULL,该列的缺省值将是该列表所允许值的第一个成员。每个枚举值均有一个索引值。

  在列说明中列表值所允许的成员值被从1开始编号。

  空字符串错误值的索引值为0。这就意味着,你可以使用下面所示的SELECT语句找出被赋于无效ENUM值的记录行。mysql>SELECT*FROMtbl_nameWHEREenum_col=0;

  MySQL数据库中ENUM类型是什么意思

  NULL值的索引值为NULL。例如,指定为ENUM("one","two","three")的一个列,可以有下面所显示的任一值。每个值的索引值也如下所示:值索引值NULLNULL""0"one"1"two"2"three"3换个枚举最大可以有65535个成员值。从MySQL3.23.51开始,当表被创建时,ENUM值尾部的空格将会自动删除。当为一个ENUM列赋值时,字母的大小写是无关紧要的。然而,以后从列中检索出来的值的大小写却是匹配于创建表时所指定的允许值。

  如果在一个数字语境中检索一个ENUM,列值的索引值将被返回。例如,你可以像这样使用数字值检索一个ENUM列:mysql>SELECTenum_col+0FROMtbl_name;

  如果将一个数字存储到一个ENUM中,数字被当作为一个索引值,并且存储的值是该索引值所对应的枚举成员。(但是,这在LOADDATA将不能工作,因为它视所有的输入均为字符串。)在一个ENUM字符串中存储数字是不明智的,因为它可能会打乱思维。

  ENUM值依照列规格说明中的列表顺序进行排序。(换句话说,ENUM值依照它们的索引号排序。)举例来说,对于ENUM("a","b"),"a"排在"b"后,但是对于ENUM("b","a"),"b"却排在"a"之前。空字符串排在非空字符串前,NULL值排在其它所有的枚举值前。为了防止意想不到的结果,建议依照字母的顺序定义ENUM列表。也可以通过使用GROUPBYCONCAT(col)来确定该以字母顺序排序而不是以索引值。

  如果希望得到一个ENUM列的所有可能值,可以使用SHOWCOLUMNSFROMtable_nameLIKEenum_colum来实现。

以上就是MySQL数据库中ENUM类型的作用是什么,小编相信有部分知识点可能是我们日常工作会见到或用到的。希望你能通过这篇文章学到更多知识。更多详情敬请关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI