MySQL枚举与集合类型的应用-创新互联

本文主要给大家介绍MySQL枚举与集合类型的应用,文章内容都是笔者用心摘选和编辑的,具有一定的针对性,对大家的参考意义还是比较大的,下面跟笔者一起了解下MySQL枚举与集合类型的应用吧。

从网站建设到定制行业解决方案,为提供网站设计、网站制作服务体系,各种行业企业客户提供网站建设解决方案,助力业务快速发展。创新互联将不断加快创新步伐,提供优质的建站服务。

1. 背景

* MySQL数据库提供针对字符串存储的两种特殊数据类型:枚举类型ENUM和集合类型SET,集合类型数据类型可以给予我们更多提高性能、降低存储容量和降低程序代码理解的技巧。

2. 枚举与集合类型所属空间与大成员数量

类型占用字节
大成员数量
ENUM1 or 2, 取决于枚举成员的数量65535
SET1|2|3|4|8,取决于集合成员的数量64

3. 枚举与集合约束检查应用

  * 创建表 e_s

mysql> CREATE TABLE e_s(
    -> uid BIGINT PRIMARY KEY NOT NULL AUTO_INCREMENT,
    -> sex ENUM('male', 'female') NOT NULL
    -> )ENGINE=INNODB CHARSET=utf8mb4;
Query OK, 0 rows affected (0.06 sec)

* 清空约束检查SQL_MODE

mysql> set sql_mode='';
Query OK, 0 rows affected (0.01 sec)

  * 插入正常数据 [ 值在枚举成员中 ]

mysql> INSERT INTO e_s SELECT null, 'male';
Query OK, 1 row affected (0.03 sec)
Records: 1  Duplicates: 0  Warnings: 0

  * 插入非正常数据 [ 值不在枚举成员中 ] [只是警告]

mysql> INSERT INTO e_s SELECT null, 'males';
Query OK, 1 row affected, 1 warning (0.03 sec)
Records: 1  Duplicates: 0  Warnings: 1

  * 查看插入非正常数据的warning

mysql> SHOW WARNINGS;
+---------+------+------------------------------------------+
| Level   | Code | Message                                  |
+---------+------+------------------------------------------+
| Warning | 1265 | Data truncated for column 'sex' at row 1 |
+---------+------+------------------------------------------+
1 row in set (0.00 sec)

  * 查看 e_s 表所有数据 [ 非法插入的ENUM列会显示为空 ]

mysql> SELECT * FROM e_s;
+-----+------+
| uid | sex  |
+-----+------+
|   1 | male |
|   3 |      |
+-----+------+
2 rows in set (0.01 sec)

  * 设置SQL_MODE 约束检查

mysql> SET sql_mode = 'STRICT_TRANS_TABLES';
Query OK, 0 rows affected (0.00 sec)

  * 插入非正常数据 [ 值不在枚举成员中 ] [ 报错返回 ]

mysql> INSERT INTO e_s SELECT null, 'males';
ERROR 1265 (01000): Data truncated for column 'sex' at row 1

4. 总结

以需求驱动技术,技术本身没有优略之分,只有业务之分。

看完以上关于MySQL枚举与集合类型的应用,很多读者朋友肯定多少有一定的了解,如需获取更多的行业知识信息 ,可以持续关注我们的行业资讯栏目的。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


网站栏目:MySQL枚举与集合类型的应用-创新互联
文章地址:http://ybzwz.com/article/gsoej.html