mysql emum设置_mysql中的数据类型enum和set

mysql中的字符串数据类型set,enum

原文网址:

https://www.cnblogs.com/benbenzhu/p/5604598.html

1、enum

单选字符串数据类型,适合存储表单界面中的“单选值”。

设定enum的时候,需要给定“固定的几个选项”;存储的时候就只存储其中的一个值。

设定enum的格式:

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

实际上,enum的选项都会对应一个数字,依次是1,2,3,4,5...,最多有65535个选项

使用的时候,可以使用选项的字符串格式,也可以使用对应的数字。

2、set

多选字符串数据类型,适合存储表单界面的“多选值”。

设定set的时候,同样需要给定“固定的几个选项”;存储的时候,可以存储其中的若干个值。

设定set的格式:

set("选项1","选项2","选项3",...)

同样的,set的每个选项值也对应一个数字,依次是1,2,4,8,16...,最多有64个选项

使用的时候,可以使用set选项的字符串本身(多个选项用逗号分隔),也可以使用多个选项的数字之和(比如:1+2+4=7)

代码如下:

48304ba5e6f9fe08f3fa1abda7d326ab.png

/* 创建表格 */

mysql> create table enum_set_table(

-> id int auto_increment primary key,

-> gender enum('M','F'),

-> hobby set('music','movie','swimming','footbal')

-> );

Query OK, 0 rows affected (0.01 sec)

/* 一个enum值,一个set值,二者均使用选项的字符串格式 */

mysql> insert into enum_set_table(id,gender,hobby) values(null,'M','music');

Query OK, 1 row affected (0.01 sec)

/* 一个enum值,多个set值,二者均使用选项的字符串格式 */

mysql> insert into enum_set_table(id,gender,hobby) values(null,'F','music,movie,footbal');

Query OK, 1 row affected (0.00 sec)

/* 一个enum值,一个set值,二者均使用选项的数字格式 */

mysql> insert into enum_set_table(id,gender,hobby) values(null,1,1);

Query OK, 1 row affected (0.00 sec)

/* 一个enum值,多个set值,二者均使用选项的数字格式,其中enum的值 2<=>'F',15=1+2+4+8 <=> 'music,movie,swimming,footbal' */

mysql> insert into enum_set_table(id,gender,hobby) values(null,2,15);

Query OK, 1 row affected (0.00 sec)

/* 一个enum值,多个set值,enum值使用选项的字符串格式,set值使用选项的数字格式,7=1+2+4 <=> 'music,movie,swimming' */

mysql> insert into enum_set_table(id,gender,hobby) values(null,'F',7);

Query OK, 1 row affected (0.01 sec)

/* 查询结果 */

mysql> select * from enum_set_table;

+----+--------+------------------------------+

| id | gender | hobby |

+----+--------+------------------------------+

| 1 | M | music |

| 2 | F | music,movie,footbal |

| 3 | M | music |

| 4 | F | music,movie,swimming,footbal |

| 5 | F | music,movie,swimming |

+----+--------+------------------------------+

5 rows in set (0.00 sec)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值