Set
集合set:是一种将多个数据选项可以同时保存的数据类型,本质是将指定的项按照对应的二进制位来进行控制:1表示该选项被选中。0表示该选项没有被选中
基本语法:set('值1','值2','值3'...)
系统为set提供了多个字节进行保存,但是系统会自动计算来选择具体的存储单元。
1个字节:set只能有8个选项
2个字节:set只能有16个选项
3个字节:set只能有24个选项
8个字节:set只能有64个选项
Set和enum一样,最终存储到数据字段中的依然是数字而不是真实的字符串。
插入数据:可以插入多个数据,就是在数据插入的字符串中,使用对应的逗号","将选项进行隔开。数据选项所在的数据与数据插入的顺序无关,最终都会变成选项对应的顺序。
分析数据存储的方式:系统将对应的数据选项(设计)按照顺序进行编排:从第一个开始进行占位,每一个都对应一个二进制位。数据在存储的时候如果被选中,那么对应的位的值就为1,否则为0。系统在进行存储的时候会自动将得到的最终的二进制颠倒过来,然后再进行转换成十进制存储。(颠倒的目的是因为数据不够位数时会补0,数据往往很大,会增加系统计算负担)
mysql> create table data_set(
-> hobby set('足球','篮球','乒乓球','羽毛球','排球')
-> )charset=utf8;
Query OK, 0 rows affec