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

mysql 枚举类型set

基础概念

MySQL中的枚举类型(ENUM)和集合类型(SET)都是预定义值的数据类型,用于限制字段只能存储特定的值。它们之间的主要区别在于:

  • ENUM:允许列存储一个预定义的值列表中的一个值。
  • SET:允许列存储一个或多个预定义的值列表中的值。

相关优势

  • 数据完整性:通过限制字段只能存储特定的值,可以确保数据的准确性和一致性。
  • 节省空间:相比于使用VARCHAR类型存储相同的值,ENUM和SET类型通常占用更少的存储空间。
  • 查询效率:由于值是预定义的,MySQL可以优化对这些字段的查询。

类型

  • ENUM:例如,定义一个性别字段,只能存储“男”或“女”。
  • ENUM:例如,定义一个性别字段,只能存储“男”或“女”。
  • SET:例如,定义一个兴趣爱好字段,可以存储多个兴趣爱好。
  • SET:例如,定义一个兴趣爱好字段,可以存储多个兴趣爱好。

应用场景

  • ENUM:适用于只有有限几个选项的场景,如性别、状态(如“待审核”、“已发布”)等。
  • SET:适用于需要存储多个选项的场景,如用户的兴趣爱好、技能标签等。

常见问题及解决方法

问题1:如何添加新的枚举值?

解决方法: 对于ENUM类型,添加新的值需要修改表结构,这可能会导致数据丢失或不一致。建议在设计表结构时就考虑周全。

代码语言:txt
复制
ALTER TABLE users MODIFY COLUMN gender ENUM('男', '女', '未知');

问题2:如何查询集合类型中的特定值?

解决方法: 可以使用FIND_IN_SET函数来查询集合类型中的特定值。

代码语言:txt
复制
SELECT * FROM users WHERE FIND_IN_SET('阅读', hobbies);

问题3:枚举类型和集合类型的性能问题

解决方法: 虽然ENUM和SET类型在存储上有一定优势,但在某些情况下可能会影响性能,特别是在大数据量和高并发的情况下。可以考虑使用关联表来替代。

代码语言:txt
复制
-- 使用关联表替代SET类型
CREATE TABLE user_hobbies (
    user_id INT,
    hobby VARCHAR(50),
    PRIMARY KEY (user_id, hobby)
);

参考链接

希望这些信息对你有所帮助!如果有更多问题,欢迎继续提问。

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

相关·内容

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
  • JPA不识别MySQL枚举类型

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

    7000

    MySQL 枚举类型的“八宗罪”

    / MySQL枚举(ENUM)类型是程序员群体中的一个讨论热点。...很重要的一点,当更改ENUM类型字段的枚举集合时,MySQL会转换任意已有但不存在于新的枚举集合中的记录值为''(空的字符串)。使用关系表,在更改和删除枚举集合时会灵活很多(下面会提到)。 3....同样,MySQL 会为ENUM值关联枚举索引,并且在使用中会错误地调用到索引而不是ENUM值,反之亦然。...MySQL 会将我们地数值型数据当作是枚举索引去处理(并没有错,但会令人混淆),根据索引可知,ENUM字段的第一个值为 0 。(译:枚举索引由 1 开始) 8....ENUM 的移植性不佳 ENUM类型不是SQL标准,属于MySQL,而其他DBMS不一定有原生的支持。

    4.4K52

    枚举类型

    枚举合起来的意思就是例举出有限的事物的集合!例如:例举一周有几天、一年有多少个月份。 枚举的正式解释:枚举类型是jdk5中新增的特性,它是一种加了限制的特殊的class类型。...这里的限制指的是对枚举类型所能创建的对象的个数进行了限制!他不像普通的class类那样可以创建无数的对象,他只能创建固定数目的对象,而且这些对象是在定义枚举类型的时候就已经在枚举类内部创建好了的!...static Enum valueOf(String name) 返回带指定名称的指定枚举类型枚举常量 int ordinal() 返回枚举常量的序数(初始常量序数为零) String toString...EnumSet和EnumMap 4.1、EnumSet 此枚举集合类EnumSet实现了Set集合接口,是一个抽象类,他可以将一个枚举类转换成一个Set集合!...其中键是枚举常量,值是字符串类型 具体转换操作如下所示!

    82810

    【说站】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

    枚举类型浅析

    但是枚举类的构造器有很大不同:首先,构造器只是在构造枚举值时使用;其次,构造器是private的,不允许为public(这样可以保证外部代码无法新构造枚举类的实例。...3、所有枚举类都继承了Enum的方法,下面我们详细介绍这些方法。   (1)  ordinal()方法: 返回枚举值在枚举类种的顺序。这个顺序根据枚举值声明的顺序而定。  ...(5)  valueOf()方法: 这个方法和toString方法是相对应的,返回带指定名称的指定枚举类型枚举常量。  (6)  equals()方法: 比较两个枚举类对象的引用。...return x * y; case DIVIDE: return x / y; } throw new AssertionError("Unkonwn op:" + this); } } 枚举类型是编译安全类型...枚举构造器不可以访问枚举的静态域,除了编译时常量域除外。

    83130

    TypeScript 枚举类型

    使用枚举我们可以定义一些带名字的常量。 使用枚举可以清晰地表达意图或创建一组有区别的用例。 TypeScript支持数字的和基于字符串的枚举。...因为 JavaScript 中并没有存在枚举类型,因此为了能够在大多数浏览器中正常运行,上面定义的 RequestMethod 枚举会被编译成以下 ES5 代码: "use strict"; var RequestMethod...利用这个特性,在确保不出现冲突的提前下,我们还可以合并在不同文件中定义的相同名称的枚举或分开定义枚举。...当一个表达式满足下面条件之一时,它就是一个常量枚举表达式: 一个枚举表达式字面量(主要是字符串字面量或数字字面量); 一个对之前定义的常量枚举成员的引用(可以是在不同的枚举类型中定义的); 带括号的常量枚举表达式...字符串枚举的概念很简单,在一个字符串枚举里,每个成员都必须用字符串字面量,或另外一个字符串枚举成员进行初始化。

    1.5K10

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

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

    3K30

    TypeScript-枚举类型

    前言 介绍其基本概念、语法特性以及如何开始使用它来构建类型安全的JavaScript应用程序。无论您是新手还是有经验的开发者,都能在这篇文章中找到有关TypeScript的重要信息和实用技巧。...枚举类型是 TS 为 JS 扩展的一种类型,在原生的 JS 中是没有枚举类型的,枚举用于表示固定的几个取值 例如:一年只有四季、人的性别只能是男或者女 定义枚举 enum Gender { Male..., Female } 如上代码的含义为,定义了一个名称叫做 Gender 的枚举类型, 这个枚举类型的取值有两个, 分别是 Male 和 Female: enum Gender { Male...数值类型,所以赋值一个数值不会报错: enum Gender { Male, Female } let val: Gender; val = 0; console.log(val);...console.log(Gender.Male); console.log(Gender.Female); 图片 TS 中的枚举类型的取值, 默认是从上至下从 0 开始递增的: enum Gender

    19520

    C语言(枚举类型

    C语言中的枚举类型常年跑龙套当配角,不受待见,这当然是有其个人原因的。今天来个小知识,看看枚举为什么那么衰,也顺便看看怎么用。 我们先来回忆一下为什么需要枚举枚举究竟是个什么东东?...话说在很久很久以前,我们的祖先在编程的时候,发现只要整型就够了,于是发明了很多像int、short、long等的数据类型。...indigo, purple}; enum spectrum color; 注意到上面两行代码,第一行是所谓的枚举类型定义及其常量列表,实际上就定义了枚举变量的有效范围,从red(即1)开始,到purple...(即7),超过此范围的,对于枚举类型 enum spectrum 而言都是非法的,因此变量 color 的取值只能是red 到 purple。...= red + orange; // 错误,枚举不能相加减 从以上几行代码看出来,枚举类型是为了达到两个目的:第一,限定有效范围。

    1.8K30

    Java枚举类型使用

    在编程中,常常遇到多种类型、多种状态的情况,对于这种可以事先预知的业务我们常常有两种表示方法: 使用DB管理,优点是方便在线维护,缺点是每次加载都要读取数据库,加载的性能取决于数据库的压力 。...使用枚举类型,优点是加载速度依赖于应用服务器,缺点是修改比较麻烦,每次加类型都需要发布代码。...对于Java枚举类型的使用,我们可以总结为以下几个方面:整型值,字符串字段和字符串的相关描述,下面我们就讨论如何方便的在这几个类型中相关转换,对于所有的类型转换可以总结如下: int --> Enum...String -->Enum Enum-->String Enum-->描述 int -->描述 String -->描述 下面我们对于上面的7种描述来做出对应的转换方法,首先定义一个枚举类型...public enum EnumDemo { fail, success, unknow; } 为了能够保证相关的value和值能够保存下来,我们需要对枚举类型改成如下

    2.2K20
    领券