mysql基础(11)_列类型之字符串型【三】_set

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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值