首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

mysqlENUM类型

ENUM类型 ENUM类型也叫作枚举类型,ENUM类型的取值范围需要在定义字段时进行指定。设置字段值时,ENUM类型只允许从成员中选取单个值,不能一次选取多个值。...举例: 创建表如下: CREATE TABLE test_enum( season ENUM('春','夏','秋','冬','unknow') ); 添加数据: INSERT INTO test_enum...VALUES('春'),('秋'); INSERT INTO test_enum VALUES('UNKNOW'); 忽略大小写 [在这里插入图片描述] 当添加个没有定义的数值时,就会报错 [在这里插入图片描述...] 当添加多个定义的值,也会报错 [在这里插入图片描述] 可以使用索引进行枚举元素的调用,下标从 1 开始# 允许按照角标的方式获取指定索引位置的枚举值 INSERT INTO test_enum VALUES...('1'),(3); SELECT * FROM test_enum;[在这里插入图片描述] 没有限制非空的情况下,可以添加null值# 当ENUM类型的字段没有声明为NOT NULL时,插入NULL

1.7K20

MySQLENUM类型学习--MySql语法

这说明你可以使用下面的SELECT语句来找出分配了非法ENUM值的行: · mysql> SELECT * FROM tbl_name WHERE enum_col=0;...当创建表时,ENUM成员值的尾部空格将自动被删除。 当检索时,保存在ENUM列的值使用列定义中所使用的大小写来显示。请注意可以为ENUM列分配字符集和 校对规则。...例如,你可以这样从ENUM列搜索数值值: mysql> SELECT enum_col+0 FROM tbl_name; 如果将一个数字保存到ENUM列,数字被视为索引,并且保存的值是该索引对应的枚举成员...(换句话说,ENUM值根据索引编号进行排序)。例如,对于ENUM('a','b'),'a'排在'b'前面,但对于ENUM('b','a'),'b'排在'a'前面。...如果你想要确定一个ENUM列的所有可能的值,使用SHOW COLUMNS FROM tbl_name LIKE enum_col,并解析输出中第2列的ENUM定义。

1.4K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL精选 | 枚举类型ENUM的DDL变更测试

    测试基于InnoDB存储引擎上,对MySQL数据库枚举类型ENUM的字段进行DDL变更操作,是否需要重新创建表呢?对数据库的事务处理有何影响?对数据库的数据服务提供有何性能影响?通过本文了解下。...数据库枚举类型字段没有显式创建索引信息时,即使符合MySQL数据库使用索引条件要求的SQL语句,也无索引信息可用,也即MySQL数据库枚举类型字段值域列表中的存储序列编号,无法做到替代索引的作用,也即依然需要显式创建数据库索引...,还是非常好的支持,并不需要创建临时表等操作,对于枚举类型字段上的索引也是同样适用的,关于这方面的文章可参考MySQL 5.5版本对普通索引增删性能的优化。...(五) 总结 ---- 通过上述对MySQL数据库表枚举类型字段的定义属性和索引方面的DDL变更操作,观察对枚举类型字段存储的数据影响,可以得出下列结论: a....MySQL数据库枚举类型字段与其他数据类型一样,进行DDL变更操作可能产生的影响; b.

    3K30

    枚举类型enum用法(enum类型)

    Java5新增了enum 关键字(与calss、interface 关键字用法相同),用来定义枚举类。 【2】为什么需要枚举类?...对枚举的扩展 switch( )的控制表达式(即括号中的条件)可以是任何枚举类型;当switch控制表达式使用枚举类型时,后面case表达式中的值可以直接使用枚举值的名字,而无需添加枚举类作为限定...(3)所有枚举类都继承了 java.lang.Enum 抽象类,所以枚举类可以直接使用 java.lang.Enum 类中所包含的方法 //java.lang.Enum package java.lang...> other = (Enum)o; Enum self = this; if (self.getClass() !...Operation2.DIVIDE.eval(4,2)); //2.0 } } 需要注意的是:枚举类里定义抽象方法时不能使用 abstract 关键字将枚举类定义成抽象类,因为系统会自动为它添加

    3K20

    MySQLenum 插入的时候注意事项

    后来发现是enum字段没有加引号搞的鬼。 结论:    enum的字段,在插入的时候,必须带上引号。否则会出现不可预期的问题。...ENUM枚举     一般不建议使用,后期不便于扩展。任何不在枚举的范围的值插入都会报错,一般用tinyint替代ENUM比较合适。      ENUM的字段值不区分大小写。...补充: enum的存储原理: (http://justwinit.cn/post/7354/?...utm_source=tuicool&utm_medium=referral) 在建立enum类型的字段时,我们会给他规定一个范围比如 enum('a','b','c'),这时mysql内部会建立一张hash...同样,enummysql手册上的说明: ENUM('value1','value2',...) 1或2个字节,取决于枚举值的个数(最多65,535个值) 除非enum的个数超过了一定数量,否则他所占的存储空间也总是

    1.1K31

    C++枚举类型enumenum class

    参考链接: C++枚举 文章目录  一.关于枚举类型二.枚举类型enum的使用三.枚举类型enum class的使用 一.关于枚举类型   1. 什么是枚举类型? ...在C++中,枚举类型分为不限定作用域(enum)和限定作用域(enum class)。   2. enumenum class的区别? (为什么需要限定作用域?) ...enum与class enum区别在于是否限定其作用域。C语言规定,枚举类型(enum)的成员的可见范围被提升至该枚举类型所在的作用域内。...这便体现C++11引入枚举类(enum class)的重要性,enum class能够有效对枚举作用域进行限定,避免了枚举成员的重定义。 ...三.枚举类型enum class的使用  定义:  enum class/*枚举类型*/  {     /*枚举成员*/,                     /*枚举成员*/,

    4.6K41
    领券