MySql 字符串类型 - enum、set

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MySql 字符串类型 - enum、set

  • enum 类型和 set 类型都是用于存储“有给定值的可选字符”,比如类似表单中的单选,多选,下拉列表。


  • enum 类型(单选类型/枚举类型) : enum 类型通常用于存储表单中的“单选项”的值。 设定形式: enum('选项值1','选项值2','选项值3'.....) 这些选项值都对应了相应的“索引值”,类似素引数组的下标,但是从1开始的。 即这些选项的索引值分别为: 1,2,3, 4,... enum 类型最多可设定6535个选项。


示例: create table tab1 (id int, edu('大学','中学','小学') ); insert into tab1 (id,edu) values(1, ‘大学"); 或: insert into tab1 (id, edu)values (1,2); // 表示中学


  • set 类型(多选类型) : set 类型通常用于存储表单中的“多选项”的值。 设定形式: set('选项值1','选项值2','选项值3'.....) 这些选项值都对应了相应的“索引值”,其索引值从1开始,并“依次翻倍”。 即这些选项的索引值分别为: 1,2,4,8, 16, ... (其实就是 2的n次方) enum类型最多可设定64个选项值。


示例: create table tab2 (aihao enum('篮球','排球','足球') ); // 对应索引值为1,2,4,8 insert into tab2 (aihao) values('篮球'); 或: insert into tab2 (aihao) values('篮球,排球'); 或: insert into tab2 (aihao) values( '篮球,排球,足球'); 或: insert into tab2 (aihao) values(2); // 表示排球 (2) 或: insert into tab2 (aihao) values(3); // 表示 '篮球,排球' (1+2) 或: insert into tab2 (aihao) values (7); // 表示 '篮球,排球,足球' (1+2+4)


``` mysql> create table enumTest (id int autoincrement primary key, username varchar(20), userpass varchar(32), edu enum('小学', '中学', '大学'), likes set('篮球', '足球', '排球')); mysql> desc enumTest; +-----------+----------------------------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-----------+----------------------------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | autoincrement | | username | varchar(20) | YES | | NULL | | | userpass | varchar(32) | YES | | NULL | | | edu | enum('小学','中学','大学') | YES | | NULL | | | likes | set('篮球','足球','排球') | YES | | NULL | | +-----------+----------------------------------+------+-----+---------+----------------+


mysql> insert into enumTest (username, userpass, edu, likes) values ('user1', '123', '小学', '篮球'); mysql> select * from enumTest; +----+-----------+-----------+--------+--------+ | id | username | userpass | edu | likes | +----+-----------+-----------+--------+--------+ | 1 | user1 | 123 | 小学 | 篮球 | +----+-----------+-----------+--------+--------+


mysql> insert into enumTest (username, userpass, edu, likes) values ('user2', '123', '中学', '篮球,排球'); mysql> select * from enumTest; +----+-----------+-----------+--------+---------------+ | id | username | userpass | edu | likes | +----+-----------+-----------+--------+---------------+ | 1 | user1 | 123 | 小学 | 篮球 | | 2 | user2 | 123 | 中学 | 篮球,排球 | +----+-----------+-----------+--------+---------------+


mysql> insert into enumTest (username, userpass, edu, likes) values ('user3', '123', '大学', '篮球,排球,太阳'); ERROR 1265 (01000): Data truncated for column 'likes' at row 1


mysql> insert into enumTest (username, userpass, edu, likes) values ('user2', '123', 2, 4); mysql> select * from enumTest; +----+-----------+-----------+--------+---------------+ | id | username | userpass | edu | likes | +----+-----------+-----------+--------+---------------+ | 1 | user1 | 123 | 小学 | 篮球 | | 2 | user2 | 123 | 中学 | 篮球,排球 | | 3 | user2 | 123 | 中学 | 排球 | +----+-----------+-----------+--------+---------------+ ```


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
存储 关系型数据库 MySQL
mysql怎么查询longblob类型数据的大小
通过本文的介绍,希望您能深入理解如何查询MySQL中 `LONG BLOB`类型数据的大小,并结合优化技术提升查询性能,以满足实际业务需求。
23 6
|
1月前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
51 8
|
1月前
|
存储 Java 开发者
Java 中 Set 类型的使用方法
【10月更文挑战第30天】Java中的`Set`类型提供了丰富的操作方法来处理不重复的元素集合,开发者可以根据具体的需求选择合适的`Set`实现类,并灵活运用各种方法来实现对集合的操作和处理。
|
1月前
|
开发者
除了交集运算,Set 类型还可以用于哪些数据结构的操作?
【10月更文挑战第30天】`Set`类型在数据结构操作方面提供了丰富的功能和便利,能够帮助开发者更高效地处理各种数据集合相关的任务,提高代码的简洁性和性能。
|
1月前
|
JavaScript 前端开发 开发者
set类型可以实现数组去重等
【10月更文挑战第30天】 `Set`类型在JavaScript中提供了一种方便、高效的集合数据结构,在数组去重、集合运算、数据存在性检查等方面都有广泛的应用,能够帮助开发者更简洁、高效地处理数据。
|
1月前
|
JavaScript 前端开发 Java
除了 JavaScript,还有哪些编程语言支持 Set 类型
【10月更文挑战第30天】这些编程语言中的 `Set` 类型虽然在语法和具体实现细节上有所不同,但都提供了类似的集合操作功能,方便开发者在不同的编程场景中处理集合相关的数据和逻辑。
|
1月前
|
算法 JavaScript 前端开发
使用 Set 类型实现数组的交集运算
【10月更文挑战第30天】使用 `Set` 类型实现数组的交集运算是一种常见且有效的方法,它为我们处理数据集合的运算提供了一种便捷的途径。通过合理地运用这种方法,我们可以轻松地实现数组的交集计算,并在各种编程任务中灵活运用。
|
2月前
|
关系型数据库 MySQL
用dbeaver创建一个enum类型,并讲述一部分,mysql的enum类型的知识
这篇文章介绍了如何在DBeaver中创建MySQL表的枚举(ENUM)字段,并探讨了MySQL中ENUM类型的一些行为特点,例如ENUM值的默认排序和在插入重复值时的表现。
57 1
用dbeaver创建一个enum类型,并讲述一部分,mysql的enum类型的知识
|
2月前
|
存储 NoSQL Redis
redis-set类型
【10月更文挑战第6天】
47 1
|
2月前
|
存储 分布式计算 NoSQL
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
大数据-40 Redis 类型集合 string list set sorted hash 指令列表 执行结果 附截图
29 3