Mysql 查询—按位运算
前言:虽说这是件小事儿,但本宝宝思前想后,还是为它留下一笔,嘿嘿。反正写博客不浪费纸和笔!好久没有开启我的逗比模式了,我亲爱的乖徒弟DBA,DBB,DBAA等,好久不见你们,遥祝幸福快乐+DB。
整个事情其实使这样的,最近的项目中,有一个表,最终是这样的:一共3位,每一位的取值是1和0(额,后来还有2,哈哈哈),1代表已认证,0代表未认证。 当时为什么这么设计呢,是因为会高频率的出现 XXX 身份已认证、邮箱已认证等等的打标签,就把之前的三个字段变成了一个,当时说是按位取值运算(怎奈何,功力不到位,咱们说的按位取值运算,压根儿不是一个频道哇,尴尬5秒中)
附录:本宝宝的频道:不是有3位嘛,我一个一个字符的截取,1就是已认证,0就是未认证。嗯,这就是传说中的按位取值运算!
一、问题出现过程
上文也说到了当初这个字段为什么这么设计的,但在用的过程中,就出现了这么个问题(别笑我,虽然我现在想想当时的逻辑,我也挺想笑的,所以,实在想笑,可别憋坏了) 当时有一个查询,每一种认证状态都是一个查询条件,这个其实不重要。重要的是,每一个条件都还有 “全部” 的选项。
本宝宝当时就在想啊,我呸,我就0和1,老娘哪儿去给你弄 全部,要么未认证要么已认证,老娘难道要3*3 组合排列 or + like 爽死人的SQL拼接吗?我才不会告诉所有人,我真的拼过一次。 但结合到我蠢了N多年的经验来看,我不会,我蠢,并不代表其他人也不会(每次团队里有我,谁都不用担心智商垫底儿) 我就默默的问了我一个同事,问如果是他,他会怎么做。。。。。。呵 呵 哒 最终的结果是,在进度统计的时候,老大知道啦,刚开始我们说还是换成3个字段,老大说:不用,这个很好解决。
当时心里那个恨呀,他知道怎么做,但是不告诉我。 所幸,老大后来还是给了我一条生路+明路:位运算
二、位运算
话说,即使我明白了要用位运算,却也是一波三折。因为其实,我就在想Linux给文件授权,每次打chmod 7的时候,就是全部权限嘛,但其实是4+2+1得到的。 然后我就在测试我的那个认证状态字段,发现一个现象:我每次都不能用 status & 7 查出我期望的数据。 然后,就问我旁边的老大了:为什么我这条语句出不了效果呢,我查了查语法,没错啊,你看我都能单独查出来。
老大看了看,就跟我说:你想想你的数据类型? 我当时就想的很简单,因为是111这种格式的嘛,那这3个1其实转成二进制就是 4 2 1 ,完全没问题 啊,为什么就是查不出来呢,这个时候,刚好又遇到了另外一个case,就是要授权和取消授权。 我当时就特别蒙,你说授权方便,我直接更改数值,但取消授权,我怎么做呢?我当时想了好久都很苦恼,后来老大说:你就没有理解什么是位运算,好好想想。 后来我就想明白了:第一,我们当时用的数据类型是char,这本身就不对;第二,授权或者取消授权,只要加减对应的数值就OK了,做位运算的时候,会转换成二进制运算。所以,后来的处理方案是:
1,首先将char类型,转换为了int;2,对应的语句大概是:查询 where status & 1 ; set status=status+1 或者set status=status-1等。 举个例子:我们设置1为个人认证;2为邮箱认证;4为渠道认证;8为主管理员认证; 那如果要查询即通过个人认证(1),又通过了渠道认证(4)的数据,那么语句应该是:where status & 5,直接将数值加起来作为条件。
最合适的类比,我用到过得,也就只有Linux的授权chmod了
附录:具体的,随便搜就能找到资料,我就不copy and paste了哈
三、个人总结
其实,写这篇文章,最主要不是记录这个位运算的具体查询和使用,而是,老大明明就知道具体该怎么做,然而,他为什么没有直接告诉我呢? 说实在的,这个东西当时也就卡着了,他老人家就看我在那儿折腾。 而且,我不会,还专门挑我去解决这个事儿。
其实,就突然想起来之前老大让我去做一个分享的时候,我们的一次对话:
老大:怎么样啊,7点就要开始了,你准备准备?
我:PPT就是那天早上给你看的,哎呀,不用准备的,我就是块砖,主要的用途就是引出你这块玉,我说不下去了,不是还有你顶着嘛,嘿嘿
老大:你应该想想自己怎么能够成为那块玉,别把自己当砖使! (PS: 也许,这就是领导和小兵的区别)
我,也要成为一个被团队依靠的人,加油!
Mysql 查询—按位运算的更多相关文章
- C#中缓存的使用 ajax请求基于restFul的WebApi(post、get、delete、put) 让 .NET 更方便的导入导出 Excel .net core api +swagger(一个简单的入门demo 使用codefirst+mysql) C# 位运算详解 c# 交错数组 c# 数组协变 C# 添加Excel表单控件(Form Controls) C#串口通信程序
C#中缓存的使用 缓存的概念及优缺点在这里就不多做介绍,主要介绍一下使用的方法. 1.在ASP.NET中页面缓存的使用方法简单,只需要在aspx页的顶部加上一句声明即可: <%@ Outp ...
- MySQL使用位运算
通常 我们的数据表中 可能会包含各种状态属性, 例如 blog表中,我们需要有字段表示其是否公开,是否有设置密码,是否被管理员封锁,是否被置顶等等. 也会遇到在后期运维中,策划要求增加新的功能而造成你 ...
- mysql时间加减运算
一.MySQL 获得当前日期时间 函数 1.1 获得当前日期 + 时间(date + time) 函数:now() mysql> select now();+———————+| now() |+ ...
- MYSQL查询语句大全集锦
MYSQL查询语句大全集锦 1:使用SHOW语句找出在服务器上当前存在什么数据库: mysql> SHOW DATABASES; 2:2.创建一个数据库MYSQLDATA mysql> C ...
- 位运算在 PHP 实际项目当中的高级运用
我们首先来看一个系统中常见的需求: 有一个广告表,我们要对广告做显示控制: 手动上下线. 只允许 VIP 查看. 可能的表结构如下: CREATE TABLE `finger_ad` ( `ad_id ...
- Java二进制和位运算,这一万字准能喂饱你
基础不牢,地动山摇.本文已被 https://www.yourbatman.cn 收录,里面一并有Spring技术栈.MyBatis.JVM.中间件等小而美的专栏供以免费学习.关注公众号[BAT的乌托 ...
- SQL Server时间粒度系列----第8节位运算以及设置日历数据表节假日标志详解
本文目录列表: 1.位运算 2.设置日历数据表节假日标志 3.总结语 4.参考清单列表 位运算 SQL Server支持的按位运算符有三个,分别为:按位与(&).按位或(|).按位异或 ...
- EF架构~为分组添加位运算聚合方法
回到目录 我们知道在Linq里的分组groupby可以对集合中一个或者多个字段进行分组,并对其中一个属性进行聚合,而Linq为我们提供了多种聚合方法,由aver,sum,count等,而在大叔权限体系 ...
- 蓝桥杯---汉字取首字母(位运算 & 水题)
确实题目虽然有点水,但是开始的时候好像还真的没有想到怎么提取出这个编号一不小心感觉可以可以用unsigned char 这种类型,直接转为16进制,但是之后发现虽然第一次在codeblock中还行,但 ...
随机推荐
- npm包发布过程
在上一章节中,我封装了一个基于react的树状组件,后来想把它发布到npm上,下面主要介绍一下发布过程中遇到的问题: 1.去注册npm账号,注册地址(https://www.npmjs.com), 再 ...
- jQuery实现轮播切换以及将其封装成插件(1)
我们在网上经常会看到一些轮播切换的效果.轮播切换,就是在一个有限的空间中定时的像走马灯一样去播放一组图片,当然也可以通过鼠标悬停在小按钮上来切换显示.下面我们将一步一步的实现这一效果. 为保证效果,请 ...
- VisualSVN 4.0.10 破解版 附上破解过程
VisualSVN一般情况下使用不需要破解,可以直接使用社区授权.但是社区授权不支持域用户. 如果要再域下面使用就需要破解了. 原版的VisualSVN和破解后的DLL已打包上传(仅供学习使用) 破解 ...
- 用dockers实现mysql主从同步
首先要先看看当前的mysql的版本是什么,可以通过下面命令查看 mysql --version 最好是安装在docker中的mysql和你宿主机器中的mysql版本一致. 我的是mysql5.7.22 ...
- 【杂题总汇】NOIP2013(洛谷P1967) 货车运输
[洛谷P1967] 货车运输 重做NOIP提高组ing... +传送门-洛谷P1967+ ◇ 题目(copy from 洛谷) 题目描述 A国有n座城市,编号从1到n,城市之间有m条双向道路.每一条道 ...
- 【例题收藏】◇例题·I◇ Snuke's Subway Trip
◇例题·I◇ Snuke's Subway Trip 题目来源:Atcoder Regular 061 E题(beta版) +传送门+ 一.解析 (1)最短路实现 由于在同一家公司的铁路上移动是不花费 ...
- 基于mybatis设计简单OA系统问题1
全类名与全路径 全类名是某个文件在项目中的位置,格式为包名.类名 路径分为相对路径和绝对路径. 绝对路径是指这个文件在操作系统中的位置, 相对路径通过这个文件的上一级 ./ 或下一级/ 来指定文件 ...
- nginx 报错: nginx: [emerg] open() "/etc/nginx/nginx.conf" failed (2: No such file or directory)
执行: /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf https://www.cnblogs.com/codingcl ...
- linux 开机自启动 Tomcat
1.修改脚本文件rc.local:vim /etc/rc.d/rc.local 这个脚本是使用者自定的开机启动程序,可以在里面添加想在系统启动之后执行的脚本或者脚本执行命令 2.添加如下内容: exp ...
- IDEA 工具项目的配置及如何打war包
1. Project Structure 1.1 首先点击File-ProjectStructure,进入项目配置: 2.Project Settings配置 2.1 Project 2.1.1 f ...