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

mysql 添加enum

基础概念

MySQL中的ENUM是一种字符串对象,用于指定一个列可以拥有的预定义值集合。它类似于一个固定长度的字符串类型,但具有更高的效率和存储空间优化。ENUM类型的列在创建时必须指定一组可能的值,每个值用逗号分隔,并且这些值会被映射到整数值,其中第一个值为1,第二个值为2,依此类推。

优势

  1. 存储效率ENUM类型使用较少的磁盘空间,因为它以整数形式存储值。
  2. 查询速度:由于ENUM值被映射为整数,所以查询速度通常比文本类型快。
  3. 数据完整性:通过限制列的值只能是预定义的集合,可以保证数据的完整性和一致性。

类型

ENUM类型没有子类型,它只是一个值的列表。

应用场景

ENUM类型适用于那些列的值是有限且固定的情况,例如性别(男、女)、星期(星期一、星期二...)、状态(待审核、已审核、已发布)等。

如何添加ENUM

要在MySQL中为一个列添加ENUM类型,可以使用ALTER TABLE语句。以下是一个示例:

代码语言:txt
复制
ALTER TABLE your_table_name
MODIFY your_column_name ENUM('value1', 'value2', 'value3');

在这个例子中,your_table_name是你要修改的表的名称,your_column_name是你要修改的列的名称,而'value1', 'value2', 'value3'是该列允许的值的列表。

可能遇到的问题及解决方法

问题:无法添加ENUM类型

原因:可能是由于列的数据类型不兼容,或者表正在被其他会话使用。

解决方法

  • 确保列当前没有数据或者可以接受转换到ENUM类型。
  • 检查是否有其他会话正在使用该表,如果是,可以等待会话结束或者终止它们。
  • 如果列中已经有数据,需要先处理这些数据,确保它们符合新的ENUM定义。

问题:ENUM值列表变更

原因:可能需要添加或删除ENUM中的值。

解决方法

  • MySQL不支持直接修改ENUM类型的值列表。一种方法是创建一个新的ENUM列,将旧列的数据迁移到新列,然后删除旧列并重命名新列。
  • 另一种方法是使用ALTER TABLE ... ADD COLUMN语句添加一个临时列,更新这个临时列的值,然后删除旧的ENUM列并将临时列转换为新的ENUM类型。

参考链接

请注意,以上信息是基于MySQL数据库的一般知识,具体实现可能会根据MySQL的版本和配置有所不同。在实际操作中,建议参考你所使用的MySQL版本的官方文档。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

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
  • 枚举类型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

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

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

    3K30

    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
    领券