文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL中Bit数据类型使用

2023-08-17 06:19

关注

Mysql Bit字段类型用来存储二进制的位值,Bit(M)代表可存储M位的二进制数据,M取值为区间为1-64。数据库Bit类型常用来存储Boolean类型的状态,也就是可以使用一个字段来存最多64个状态,如果你的系统状态够多或者将来可能会有扩展状态,那推荐使用这个类型进行处理,查询或更新某个状态时按位操作即可。

举个例子:某个系统需要保存对用户发送短信的状态,有10几种不同类型的短信,每种都要标记发过没有,这时候用bit类型就很方便。

1、准备测试表

CREATE TABLE `bit_demo` (  `id` int NOT NULL,  `name` varchar(100) DEFAULT NULL,  `flag` bit(3) DEFAULT NULL COMMENT '从低到高位依次为移动,电信,联通',  PRIMARY KEY (`id`),  KEY `idx_bit` (`flag`))

为了将来可扩展,我们一般先从低位开始使用,此处我们设计三个位,从低到高位依次为移动,电信,联通短信渠道是否完成发送,各位值上1表示true,0表示false。3个位,一共8种情况,二进制值范围:000->111,十进制范围:0->7,如下表格:

二进制十进制说明
0000所有渠道都未发送
0011移动渠道已发送
0102电信渠道已发送
0113移动、电信渠道已发送
1004联通渠道已发送
1015移动、联通渠道已发送
1106联通、电信渠道已发送
1117移动、电信、联通渠道已发送

2、如何写入bit数据

位值字面值用 b 或者 0b 做前缀,后接以 01 组成的二进制数字。其中 0b 是区分大小写的,0B 则会报错。

合法的 Bit-value:

  1. b’01’
  2. B’01’
  3. 0b01

非法的 Bit-value:

  1. b’2’ (2 不是二进制数值, 必须为 0 或 1)
  2. 0B01 (0B 必须是小写 0b)

以下三条sql插入了相同位值:

insert into bit_demo(`id`,`name`,`flag`) values(1,'张三',3);insert into bit_demo(`id`,`name`,`flag`) values(2,'李四',b'011');insert into bit_demo(`id`,`name`,`flag`) values(3,'三五',0b011);

3、bit数据查询展示

位值是作为二进制返回的,输出到 MySQL Client 可能会显示不出来**(有些client桌面工具默认展示10进制),**

file

如果要转换为可打印的字符,可以使用内建函数 BIN() 或者 HEX()来进行查询,如下内置函数:

  1. flag+0 10进制
  2. BIN(flag) 二进制
  3. OCT(flag)八进制
  4. HEX(flag) 十六进制

内置函数使用案例如下:

SELECT name,flag+0, BIN(flag), OCT(flag), HEX(flag) FROM bit_demo
file

高位为0,转换函数不会显示,从上图业务数据看出,所有用户已发送移动和电信渠道的短信.

4、修改指定位状态

  1. 如果张三用户已发送联通渠道短信,如何update数据?
  2. 如果张三用户取消电信渠道短信,如何update数据?
  3. 先把张三数据查出来,变更数据,再整体写回去?

正确姿势应该如下:

4.1、使用或运算写1值

说明:运用任何值和0做或运算,不改变原值特性,例如将011的最高位改为1的运算如下:

// 011|100=111update bit_demo set flag=flag|100 where id=1

查询结果:

file

从上图业务数据看出,张三用户所有渠道短信已发送.

4.2、使用与运算写0值

说明:运用任何值和1做与运算,不改变原值特性,例如将111的最高位改为0的运算如下:

// 111&011=011update bit_demo set flag=flag&011 where id=1

查询结果:

file

从上图业务数据看出,张三用户联通渠道短信还未发送.

4.3、使用异或运算写0或1值

说明:用异或运算修改,只会在原值基础上进行变更,最终值有可能是0也有可能是1

法则回顾:异或也叫半加运算,其运算法则相当于不带进位的二进制加法,例子:

   110^  100=  010
update bit_demo set flag=flag^b'100' where id=1;
file

5、如何根据某位状态查询

  1. 如何查询所有已发送过电信渠道短信的数据?
  2. 如何查询所有未发送电信渠道短信的数据?

原理:将数据库值先作位运算,再作对比
任意数据xxx和010作&运算,都等于0x0格式

# 查询已发送电信渠道数据SELECT id,name,flag+0, BIN(flag) FROM bit_demo where flag&010=b'010'或SELECT id,name,flag+0, BIN(flag) FROM bit_demo where flag&010=2
file
# 查询未送电信渠道数据SELECT id,name,flag+0, BIN(flag) FROM bit_demo where flag&010=b'000'或SELECT id,name,flag+0, BIN(flag) FROM bit_demo where flag&010=0
file

完!

来源地址:https://blog.csdn.net/qusikao/article/details/127899715

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯