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

mysql set枚举

基础概念

MySQL中的SET是一种数据类型,用于存储一组预定义的字符串值。每个值都是唯一的,并且可以有多个值同时存在。SET类型在数据库设计中常用于表示一组有限的选项,例如用户的角色、商品的类型等。

相关优势

  1. 节省空间:相比于使用多个VARCHAR字段来存储多个选项,SET类型可以更有效地利用存储空间。
  2. 简化查询:可以使用集合操作(如INTERSECTUNION)来查询和处理SET类型的数据。
  3. 数据完整性:通过预定义的选项,可以确保数据的完整性和一致性。

类型

MySQL中的SET类型没有具体的子类型,它是一个独立的数据类型。定义SET类型时,需要指定一组可能的值,例如:

代码语言:txt
复制
CREATE TABLE users (
    id INT PRIMARY KEY,
    role SET('admin', 'user', 'guest')
);

应用场景

  1. 角色管理:在用户表中存储用户的角色信息,如管理员、普通用户、访客等。
  2. 商品类型:在商品表中存储商品的类型信息,如电子产品、家居用品、服装等。
  3. 功能开关:在配置表中存储功能的开启或关闭状态。

遇到的问题及解决方法

问题1:插入非法值

原因:尝试插入不在预定义选项中的值。

解决方法:在插入数据之前,进行合法性检查,确保插入的值在允许的范围内。

代码语言:txt
复制
INSERT INTO users (id, role) VALUES (1, 'admin'); -- 合法
INSERT INTO users (id, role) VALUES (2, 'superadmin'); -- 非法,会报错

问题2:查询特定值

原因:需要查询具有特定SET值的记录。

解决方法:使用FIND_IN_SET函数进行查询。

代码语言:txt
复制
SELECT * FROM users WHERE FIND_IN_SET('admin', role);

问题3:更新SET

原因:需要更新已有的SET值,添加或删除某些选项。

解决方法:使用集合操作符|(添加)和&~(删除)来更新SET值。

代码语言:txt
复制
UPDATE users SET role = role | 'user' WHERE id = 1; -- 添加'user'角色
UPDATE users SET role = role &~ 'guest' WHERE id = 2; -- 删除'guest'角色

参考链接

通过以上信息,您可以更好地理解MySQL中的SET类型及其相关应用和问题解决方法。

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

相关·内容

mysqlSET类型

SET类型 SET表示一个字符串对象,可以包含0个或多个成员,但成员个数的上限为64。设置字段值时,可以取 取值范围内的 0 个或多个值。...'), ('A,B'); SELECT * FROM test_set; [在这里插入图片描述] 插入重复的SET类型成员时,MySQL会自动删除重复的成员#插入重复的SET类型成员时,MySQL会自动删除重复的成员...INSERT INTO test_set (s) VALUES ('A,B,C,A');[在这里插入图片描述] 向SET类型的字段插入SET成员中不存在的值时,MySQL会抛出错误。...#向SET类型的字段插入SET成员中不存在的值时,MySQL会抛出错误。...'), hobby SET('吃饭','睡觉','打豆豆','写代码') ); INSERT INTO temp_mul VALUES('男','睡觉,打豆豆'); #成功 [在这里插入图片描述] 因为枚举类型一次只能取一个值

1.7K30
  • MySQLSET类型学习--MySql语法

    MySQL用数字保存SET值,所保存值的低阶位对应第1个SET成员。如果在数值上下文中检索一个SET值,检索的值的位设置对应组成列值的SET成员。...例如,你可以这样从一个SET列检索数值值: mysql> SELECT set_col+0 FROM tbl_name; 如果将一个数字保存到SET列中,数字中二进制表示中的位确定了列值中的SET成员。...通常情况,可以使用FIND_IN_SET()函数或LIKE操作符搜索SET值: mysql> SELECT * FROM tbl_name WHERE FIND_IN_SET('value',set_col...)>0; mysql> SELECT * FROM tbl_name WHERE set_col LIKE '%value%'; 第1个语句找出SET_col包含value set成员的行。...下面的语句也是合法的: mysql> SELECT * FROM tbl_name WHERE set_col & 1; mysql> SELECT * FROM tbl_name WHERE set_col

    4.3K10

    MySQL 枚举类型的“八宗罪”

    / MySQL枚举(ENUM)类型是程序员群体中的一个讨论热点。...很重要的一点,当更改ENUM类型字段的枚举集合时,MySQL会转换任意已有但不存在于新的枚举集合中的记录值为''(空的字符串)。使用关系表,在更改和删除枚举集合时会灵活很多(下面会提到)。 3....同样,MySQL 会为ENUM值关联枚举索引,并且在使用中会错误地调用到索引而不是ENUM值,反之亦然。...-----+| foobar | +--------+| 1 || 0 | +--------+2 rows in set (0.00 sec) 我们插入了 '1' (字符串),并且不小心插入了...MySQL 会将我们地数值型数据当作是枚举索引去处理(并没有错,但会令人混淆),根据索引可知,ENUM字段的第一个值为 0 。(译:枚举索引由 1 开始) 8.

    4.4K52

    JPA不识别MySQL枚举类型

    1 枚举好用吗?...数据字典型字段,枚举比Integer好: 限定值,只能赋值枚举的那几个实例,不能像Integer随便输,保存和查询的时候特别有用 含义明确,使用时不需要去查数据字典 显示值跟存储值直接映射,不需要手动转换...,比如1在页面上显示为启用,0显示禁用,枚举定义好可以直接显示 基于enum可以添加一些拓展方法 但默认 2 JPA不识别MySQL 的 enum 类型 会报错: Cannot determine value...3.1 EnumType.ORDINAL 按枚举的顺序保存数字。...缺点: 顺序性 java枚举的顺序从0开始递增,没法自己指定,我有些枚举并不是从0开始的,或者不是+1递增的,比如一些行业的标准代码。 旧数据可能不兼容 如-1代表删除,映射不了。

    7000

    MYSQL用法(十五) MySQL中FIND_IN_SET()用法

    FIND_IN_SET(str,strlist) 返回str在字符串集strlist中的序号(任何参数是NULL则返回NULL,如果str没找到返回0,参数1包含","时工作异常) 例子: 查询表字段...WHERE `pingid` REGEXP '{id},' AND `pingid` NOT REGEXP '[[:alnum:]]+{id},' 使用上面的语句,可以查询出来 用FIND_IN_SET...() 更简单 SELECT * FROM linkinfo WHERE FIND_IN_SET('1',pingid 原来以为mysql可以进行这样的查询----->(一) select id, list...原因其实是(一)中 (list)    list是变量, 而(二)中 ('libk', 'zyfon', 'daodao')是常量 所以如果要让(一)能正确工作,需要用find_in_set()---...select id, list, name from table where FIND_IN_SET( 'daodao' , list); 总结:所以如果list是常量,则可以直接用IN, 否则要用FIND_IN_SET

    2.9K30

    使用带有MySQL Router的Replica Set

    使用带有MySQL Router的Replica Set 您可以使用MySQL Router 8.0.19和更高版本对replica set进行引导,就像可以引导InnoDB cluster一样,将MySQL...生成的MySQL路由器配置文件的唯一区别是添加了cluster_type选项。...将MySQL路由器引导到副本集时,生成的配置文件包括: cluster_type=rs 将MySQL Router与Replica Set一起使用时,请注意: MySQL Router的读写端口将客户端连接指向...Replica Set的主实例 MySQL Router的只读端口将客户端连接定向到Replica Set的从实例,尽管它也可以将它们定向到主实例 MySQL Router从主实例获取Replica Set...的拓扑信息 当主实例不可用并且升级了另一个实例时,MySQL Router会自动恢复 只需要运行下面这条命令即可将来集群信息注册到MySQL Router中 mysqlrouter --bootstrap

    2K00

    MySQL中FIND_IN_SET探险记

    但是又要实现不同产品需要不同等级不同分组的人员管理,在做数据库查询时,需要得到某字段中包含某个值的记录,但是它也不是用like能解决的,使用like可能查到我们不想要的记录,它比like更精准,查找资料后发现涉及到数据库的特有函数,候mysql...的FIND_IN_SET函数就派上用场了,下面来具体了解一下。...FIND_IN_SET(str,strlist) 第一个参数str是要查找的字符串。 第二个参数strlist是要搜索的逗号分隔的字符串列表。...贴图: SELECT FIND_IN_SET(1,1) ? 刚说好的字符串,你就给我来个这 ? ? ? ,mysql你怎么可以这么随意呢! ? ? ? 以上图示,有劳读友自行总结 ? ? ?...5、FIND_IN_SET和like的区别 like是广泛的模糊匹配,字符串中没有分隔符,Find_IN_SET 是精确匹配,字段值以英文”,”分隔,Find_IN_SET查询的结果要小于like查询的结果

    1.9K10

    swift 枚举(枚举关联值、枚举原始值、递归枚举等)

    :Swift枚举在创建时未分配默认整数值。...原始值是在定义枚举时被预先填充的值。对于一个特定的枚举成员,它的原始值始终不变。关联值是创建一个基于枚举成员的常量或变量时才设置的值,枚举成员的关联值可以变化。...autumn case winter } 当使用字符串作为枚举类型的原始值时,每个枚举成员的隐式原始值为该枚举成员的名称 enum Season:String { case spring...) 使用原始值初始化枚举实例 可以通过rawValue初始化一个枚举成员,返回值则是枚举成员或nil 可以通过这个来判断这个新枚举成员是否在枚举值中 enum Season:Int { case...递归枚举是一种枚举类型 有一个或多个枚举成员使用该枚举类型的作为枚举成员 在枚举成员前加上indirect来表示该成员可递归 enum ArithmeticExpression { case

    30110

    MYSQL 8 如何定住你的 set variables

    这里面熟悉MYSQL的就会体会到一个情况,就是我的my.cnf 和 我实际的配置的各种变量,可能是不同的,有的变量还好,在MYSQL重启动后变回my.cnf 的配置,但有的时候变回去后,可能会给你出乱子...一般配置MYSQL的参数时候,如果我在MYSQL 运行的时候,配置一些系统或全局变量时,如果是决定的事情,我是会将这些配置,写入到my.cnf 的,下次启动一般不会有事情,但怕就是忘记了,或一些紧急处理的情况下...这个功能就是 SET PERSIST 方式来设置你的变量 我们举例 在MYSQL 8 中查看当前的 innodb_buffer_pool_size ?...并且我在重启 MYSQL 后相关的配置选项不会丢失 ? 当然如果你删除了记录的文件,则相关的配置在MYSQL 再次启动后就失效了。...select a.VARIABLE_NAME,b.VARIABLE_value ,SET_TIME,SET_USER,SET_HOST from performance_schema.variables_info

    1.1K20

    【说站】mysqlset类型如何理解

    mysqlset类型如何理 说明 1、set和enum很像,也是一个字符串对象,可以包含0~64个成员。 根据成员数量不同,存储器也不同。set类型可以一次选择多个成员。...2、可以从允许值集中选择任何元素进行组合,因此只要输入的值在允许值的组合范围内,就可以正确记录在set类型的列中。 对超出允许范围的值,报错。而且有重复成员的集合,会自动去重。...实例 --创建表ts,包含字段f1(set()) mysql> create table ts (f1 set('a','b','c','d')); mysql> insert into ts values...('a,b'),('a,d'),('b,c,d'); 以上就是mysqlset类型的理解,希望对大家有所帮助。...更多mysql学习指路:MySQL 推荐操作系统:windows7系统、mysql5.8、DELL G3电脑 收藏 | 0点赞 | 0打赏

    74630

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

    导读 ---- 本文深入介绍枚举类型EUNM和集合类型SET。测试基于InnoDB存储引擎上,对MySQL数据库枚举类型ENUM的字段进行DDL变更操作,是否需要重新创建表呢?...(0.00 sec) 小结: MySQL数据库枚举类型字段没有显式创建索引信息时,即使符合MySQL数据库使用索引条件要求的SQL语句,也无索引信息可用,也即MySQL数据库枚举类型字段值域列表中的存储序列编号...MySQL数据库枚举类型字段与其他数据类型一样,进行DDL变更操作可能产生的影响; b....MySQL数据库枚举类型字段的DDL变更操作,属于枚举类型字段特有的内容: 枚举类型字段的枚举数据值域列表,以尾部追加枚举元素值的方式,不会出现锁表等; 枚举类型字段的枚举数据值域列表中,若是调整枚举类型枚举元素值的顺序...,不会能起到MySQL数据库表索引的功能; 枚举类型字段存储的数据值,则是枚举类型枚举元素的序列编号,而不是真实的字符串数据,而是通过其内部对照表的方式转换而实现的;

    3K30
    领券