欢迎您访问 最编程 本站为您分享编程语言代码,编程技术文章!
您现在的位置是: 首页

[MySQL] 5.数据类型 - 5. 枚举和集合

最编程 2024-03-17 21:51:11
...

语法:enum:枚举,“单选”类型;

enum('选项1','选项2','选项3',...);

该设定只是提供了若干个选项的值,最终一个单元格中,实际只存储了其中一个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,3,…最多65535个;当我们添加枚举值时,也可以添加对应的数字编号。
set:集合,“多选”类型;

set('选项值1','选项值2','选项值3', ...);

该设定只是提供了若干个选项的值,最终一个单元格中,设计可存储了其中任意多个值;而且出于效率考虑,这些值实际存储的是“数字”,因为这些选项的每个选项值依次对应如下数字:1,2,4,8,16,32,…最多64个。
说明:不建议在添加枚举值,集合值的时候采用数字的方式,因为不利于阅读。
案例:
有一个调查表votes,需要调查人的喜好, 比如(登山,游泳,篮球,武术)中去选择(可以多选),(男,女)[单选]

mysql> create table votes(
    -> username varchar(30),
    -> hobby set('登山','游泳','篮球','武术'),
    -> gender enum('男','女')
    -> );
Query OK, 0 rows affected (0.01 sec)

在这里插入图片描述
这里enum的存储方式就是按下标的方式存储

mysql> insert into votes values('关羽','6','3');
ERROR 1265 (01000): Data truncated for column 'gender' at row 1
mysql> insert into votes values('关羽','6','-1');
ERROR 1265 (01000): Data truncated for column 'gender' at row 1

在这里插入图片描述

# 查找出性别为女性的人
mysql> select * from votes where gender = 2;
+----------+----------------------+--------+
| username | hobby                | gender |
+----------+----------------------+--------+
| 刘备     | 篮球                 ||
| 曹操     | 游泳,篮球,武术       ||
| 孙权     | 登山,游泳,武术       ||
+----------+----------------------+--------+
3 rows in set (0.00 sec)

mysql> select * from votes where gender = '女';
+----------+----------------------+--------+
| username | hobby                | gender |
+----------+----------------------+--------+
| 刘备     | 篮球                 ||
| 曹操     | 游泳,篮球,武术       ||
| 孙权     | 登山,游泳,武术       ||
+----------+----------------------+--------+
3 rows in set (0.00 sec)
# 查找出爱好中包含篮球的人
mysql> select * from votes where hobby = '篮球';
+----------+--------+--------+
| username | hobby  | gender |
+----------+--------+--------+
| 刘备     | 篮球   ||
+----------+--------+--------+
1 row in set (0.00 sec)

我们发现这样的SQL语句并不能准确的找出所有爱好中包含篮球的人,那应该如何操作呢?
集合查询使用find_ in_ set函数:
find_in_set(sub,str_list) :如果 sub 在 str_list 中,则返回下标;如果不在,返回0;
str_list 用逗号分隔的字符串。

mysql> select find_in_set('a', 'a,b,c');
+---------------------------+
| find_in_set('a', 'a,b,c') |
+---------------------------+
| 1                         |
+---------------------------+
mysql> select find_in_set('d', 'a,b,c');
+---------------------------+
| find_in_set('d', 'a,b,c') |
+---------------------------+
| 0                         |
+---------------------------+
# 查询爱好篮球的人:
mysql> select * from votes where find_in_set('篮球',hobby);
+----------+-----------------------------+--------+
| username | hobby                       | gender |
+----------+-----------------------------+--------+
| 刘备     | 篮球                        ||
| 曹操     | 游泳,篮球,武术              ||
| 孙权     | 登山,游泳,篮球,武术         ||
| 关羽     | 游泳,篮球                   ||
| 关羽     | 游泳,篮球                   |        |
+----------+-----------------------------+--------+
5 rows in set (0.00 sec)
# 查找同时爱好篮球和武术的人 --- 不能在一个find语句中同时查找两个属性
mysql> select * from votes where find_in_set('篮球',hobby) and find_in_set('武术',hobby);
+----------+-----------------------------+--------+
| username | hobby                       | gender |
+----------+-----------------------------+--------+
| 曹操     | 游泳,篮球,武术              ||
| 孙权     | 登山,游泳,篮球,武术         ||
+----------+-----------------------------+--------+
2 rows in set (0.00 sec)
# 同时拥有所有爱好的就可以用上限来查找
mysql> select * from votes where hobby = 15;
+----------+-----------------------------+--------+
| username | hobby                       | gender |
+----------+-----------------------------+--------+
| 孙权     | 登山,游泳,篮球,武术         ||
+----------+-----------------------------+--------+
1 row in set (0.01 sec)

推荐阅读