首页 数据库 mysql教程 mysql set跟enum记录的详解

mysql set跟enum记录的详解

Mar 30, 2017 pm 04:39 PM

mysql set和enum记录

Definition of a ENUM or SET column does act as a constraint on values entered into the column.?An error occurs for values that do not satisfy these conditions:

An ENUM value must be one of those listed in the column definition, or the internal numeric equivalent thereof.?The value cannot be the error value (that is, 0 or the empty string).?For a column defined as ENUM('a','b','c'), values such as '', 'd', or 'ax' are illegal and are rejected.

A SET value must be the empty string or a value consisting only of the values listed in the column definition separated by commas.?For a column defined as SET('a','b','c'), values such as 'd' or 'a,b,c,d' are illegal and are rejected.

以上为手册中说明的详细信息;

SET是一个字符串对象,可以有零或多个值,其值来自表创建时规定的允许的一列值。指定包括多个SET成员的SET列值时各成员之间用逗号(‘,’)间隔开。这样SET成员值本身不能包含逗号。 例如,指定为SET('one', 'two') NOT NULL的列可以有下面的任何值: '' 'one' 'two' 'one,two' SET最多可以有64个不同的成员。 当创建表时,SET成员值的尾部空格将自动被删除。 

当检索时,保存在SET列的值使用列定义中所使用的大小写来显示。请注意可以为SET列分配字符集和 校对规则。对于二进制或大小写敏感的校对规则,当为列分配值时应考虑大小写。 MySQL用数字保存SET值,所保存值的低阶位对应第1个SET成员。

如果在数值上下文中检索一个SET值,检索的值的位设置对应组成列值的SET成员。

例如,你可以这样从一个SET列检索数值值:

mysql> SELECT set_col+0 FROM tbl_name;
登录后复制

如果将一个数字保存到SET列中,数字中二进制表示中的位确定了列值中的SET成员。对于指定为SET('a','b','c','d')的列,

成员有下面的十进制和二进制值: SET成员 十进制值 二进制值 'a' 1 0001 'b' 2 0010 'c' 4 0100 'd' 8 1000 ? 如果你为该列分配一个值9,其二进制形式为1001,因此第1个和第4个SET值成员'a'和'd'被选择,结果值为 'a,d'。 

对于包含多个SET元素的值,当插入值时元素所列的顺序并不重要。

在值中一个给定的元素列了多少次也不重要。

当以后检索该值时,值中的每个元素出现一次,根据表创建时指定的顺序列出元素。

例如,

假定某个列指定为SET('a','b','c','d'):

mysql> CREATE TABLE myset (col SET('a', 'b', 'c', 'd'));
插入值'a,d'、'd,a'、'a,d,d'、'a,d,a'和'd,a,d':
mysql> INSERT INTO myset (col) VALUES
-> ('a,d'), ('d,a'), ('a,d,a'), ('a,d,d'), ('d,a,d');
Query OK, 5 rows affected (0.01 sec)
Records: 5 ?Duplicates: 0 ?Warnings: 0
登录后复制

当检索时所有这些值显示为 'a,d':

mysql> SELECT col FROM myset;
+------+
| col ?|
+------+
| a,d ?|
| a,d ?|
| a,d ?|
| a,d ?|
| a,d ?|
+------+
5 rows in set (0.04 sec)
登录后复制

如果将SET列设置为一个不支持的值,则该值被忽略并发出警告:

mysql> INSERT INTO myset (col) VALUES ('a,d,d,s');
Query OK, 1 row affected, 1 warning (0.03 sec)
?
mysql> SHOW WARNINGS;
+---------+------+------------------------------------------+
| Level ? | Code | Message ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?|
+---------+------+------------------------------------------+
| Warning | 1265 | Data truncated for column 'col' at row 1 |
+---------+------+------------------------------------------+
1 row in set (0.04 sec)
?
mysql> SELECT col FROM myset;
+------+
| col ?|
+------+
| a,d ?|
| a,d ?|
| a,d ?|
| a,d ?|
| a,d ?|
| a,d ?|
+------+
6 rows in set (0.01 sec)
登录后复制

SET值按数字顺序排序。NULL值排在非NULL 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成员的行。第2个类似,但有所不同:它在其它地方找出set_col包含value的行,甚至是在另一个SET成员的子字符串中。 下面的语句也是合法的:

mysql> SELECT * FROM tbl_name WHERE set_col & 1;
mysql> SELECT * FROM tbl_name WHERE set_col = 'val1,val2';
登录后复制

第1个语句寻找包含第1个set成员的值。第2个语句寻找一个确切匹配的值。

应注意第2类的比较。

将set值与'val1,val2'比较返回的结果与同'val2,val1'比较返回的结果不同。

指定值时的顺序应与在列定义中所列的顺序相同。 如果想要为SET列确定所有可能的值,使用SHOW COLUMNS FROM tbl_name LIKE set_col并解析输出中第2列的SET定义。   

刚才研究MySQL文档,发现SET类型的真正含义: ?   实际上,SET可以包含最多64个成员,其值为一个整数。这个整数 的二进制码表示该SET的值的哪些成员为真。例如有

SET('a','b','c','d'),
那么当它们的值为:
?
SET member ?Decimal value ?Binary value
-----------------------------
a     1        0001
b     ?2         0010
c     ?4        ?0100
d     ?8        ?1000
 
登录后复制

 如果你将9存入某个SET域,那么其二进制值为1001,也就是说这 个值中'a'和'd'为真。 ?   可以想到,如果这样的话,大家可以用LIKE命令和FIND_IN_SET() 函数来检索SET值:

?
mysql> SELECT * FROM tbl_name WHERE set_col LIKE '%value%';
mysql> SELECT * FROM tbl_name WHERE FIND_IN_SET('value',set_col)>0;
?
登录后复制

当然,以下SQL语句也是合法的,他们显得更加简洁:

?
mysql> SELECT * FROM tbl_name WHERE set_col = 'val1,val2';
mysql> SELECT * FROM tbl_name WHERE set_col & 1;
?
?
enum

mysql> show create table b;
+-------+-------------------------------------------------------------------------------------------------+
| Table | Create Table ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?|
+-------+-------------------------------------------------------------------------------------------------+
| b ? ? | CREATE TABLE `b` (
`f1` enum('a','b','c') DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=latin1 |?
+-------+-------------------------------------------------------------------------------------------------+
1 row in set (0.00 sec)
?
?
mysql> select * from b;
Empty set (0.00 sec)
?
mysql> insert into b values(1);
Query OK, 1 row affected (0.00 sec)
?
mysql> insert into b values(2);?
Query OK, 1 row affected (0.00 sec)
?
mysql> insert into b values(3);?
Query OK, 1 row affected (0.00 sec)
?
mysql> insert into b values(4);?
Query OK, 1 row affected, 1 warning (0.00 sec)
?
mysql> select * from b;?
+------+
| f1 ? |
+------+
| a ? ?|?
| b ? ?|?
| c ? ?|?
| ? ? ?|?
+------+
4 rows in set (0.00 sec)
?
登录后复制

对于enum类型一次只能是列举的某一个数值,大约个数或是0时,插入的值为空。 ? set类型适合用于复合值(类似多项选择),enum适合于单值选择(类似单项选择)。

 以上就是mysql set跟enum记录的详解的内容,更多相关内容请关注PHP中文网(www.php.cn)!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

phpmyadmin怎么打开 phpmyadmin怎么打开 Apr 10, 2025 pm 10:51 PM

可以通过以下步骤打开 phpMyAdmin:1. 登录网站控制面板;2. 找到并点击 phpMyAdmin 图标;3. 输入 MySQL 凭据;4. 点击 "登录"。

MySQL:世界上最受欢迎的数据库的简介 MySQL:世界上最受欢迎的数据库的简介 Apr 12, 2025 am 12:18 AM

MySQL是一种开源的关系型数据库管理系统,主要用于快速、可靠地存储和检索数据。其工作原理包括客户端请求、查询解析、执行查询和返回结果。使用示例包括创建表、插入和查询数据,以及高级功能如JOIN操作。常见错误涉及SQL语法、数据类型和权限问题,优化建议包括使用索引、优化查询和分表分区。

MySQL的位置:数据库和编程 MySQL的位置:数据库和编程 Apr 13, 2025 am 12:18 AM

MySQL在数据库和编程中的地位非常重要,它是一个开源的关系型数据库管理系统,广泛应用于各种应用场景。1)MySQL提供高效的数据存储、组织和检索功能,支持Web、移动和企业级系统。2)它使用客户端-服务器架构,支持多种存储引擎和索引优化。3)基本用法包括创建表和插入数据,高级用法涉及多表JOIN和复杂查询。4)常见问题如SQL语法错误和性能问题可以通过EXPLAIN命令和慢查询日志调试。5)性能优化方法包括合理使用索引、优化查询和使用缓存,最佳实践包括使用事务和PreparedStatemen

为什么要使用mysql?利益和优势 为什么要使用mysql?利益和优势 Apr 12, 2025 am 12:17 AM

选择MySQL的原因是其性能、可靠性、易用性和社区支持。1.MySQL提供高效的数据存储和检索功能,支持多种数据类型和高级查询操作。2.采用客户端-服务器架构和多种存储引擎,支持事务和查询优化。3.易于使用,支持多种操作系统和编程语言。4.拥有强大的社区支持,提供丰富的资源和解决方案。

apache怎么连接数据库 apache怎么连接数据库 Apr 13, 2025 pm 01:03 PM

Apache 连接数据库需要以下步骤:安装数据库驱动程序。配置 web.xml 文件以创建连接池。创建 JDBC 数据源,指定连接设置。从 Java 代码中使用 JDBC API 访问数据库,包括获取连接、创建语句、绑定参数、执行查询或更新以及处理结果。

docker怎么启动mysql docker怎么启动mysql Apr 15, 2025 pm 12:09 PM

在 Docker 中启动 MySQL 的过程包含以下步骤:拉取 MySQL 镜像创建并启动容器,设置根用户密码并映射端口验证连接创建数据库和用户授予对数据库的所有权限

centos安装mysql centos安装mysql Apr 14, 2025 pm 08:09 PM

在 CentOS 上安装 MySQL 涉及以下步骤:添加合适的 MySQL yum 源。执行 yum install mysql-server 命令以安装 MySQL 服务器。使用 mysql_secure_installation 命令进行安全设置,例如设置 root 用户密码。根据需要自定义 MySQL 配置文件。调整 MySQL 参数和优化数据库以提升性能。

centos7如何安装mysql centos7如何安装mysql Apr 14, 2025 pm 08:30 PM

优雅安装 MySQL 的关键在于添加 MySQL 官方仓库。具体步骤如下:下载 MySQL 官方 GPG 密钥,防止钓鱼攻击。添加 MySQL 仓库文件:rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm更新 yum 仓库缓存:yum update安装 MySQL:yum install mysql-server启动 MySQL 服务:systemctl start mysqld设置开机自启动

See all articles