php 数据库字段复用的基本原理与示例


Posted in PHP onJuly 22, 2011

一、逻辑代数基础:

1,数字用二进制表示,所有可能出现的数只有0和1两个。

2,基本运算只有“与”、“或”、“非”三种。

与运算定义为:(用 & 表示与运算)

0 & 0 = 0

0 & 1 = 0

1 & 0 = 0

1 & 1 = 1

可以简单理解为:只要有一个0,结果就是0,和乘法类似。

或运算定义为:(用 表示与运算)

0 0 = 0

0 1 = 1

1 0 = 1

1 1 = 1

可以简单理解为:只要有一个1,结果就是1,和加法类似。

二、逻辑运算示例:

01111010101010101111111111111111 & 1100000 = 1100000

一般可以理解为:

如果要获取一个数字某N位的数值,只需要将这个数字与2的N-1次方(掩码)进行与运算即可。

三、数据库字段定义:

以数据表 binary_sample为例:

create table binary_sample(

uid int unsigned not null,

status int unsigned not null default 0,

primary key(uid),

key i_s(status)

)engine=innodb;

status字段定义:

status字段数据类型为32bit的整数,为了尽可能的存储多个属性,我们将其进行如下定义:

以下所有“位”的描述顺序按照从低到高(从右到左)顺序表示。

0-2位表示用户注册状态:

000 表示新注册未被批准

001 表示注册被批准

010 表示位高级用户

011 表示管理员

100 表示超级管理员

101 保留

110 保留

111 掩码

3-5位用户性别:

000 表示性别不确定

001 表示性别为男

010 表示性别为女

011 保留

100 保留

101 保留

110 保留

111 掩码

如果我们要查询所有 男用户 则:

select * from binary_sample where status & b'111000' = b'001000';

如果我们要查询所有 管理员用户 则:

select * from binary_sample where status & b'111' = b'011';

如果我们要查询所有 男管理员用户 则:

select * from binary_sample where status & b'111111' = b'001011';

如果我们要查询所有 非 新注册未被批准用户 则:

select * from binary_sample where status & b'111' != b'000';

四,使用PHP程序进行此类计算:

define("USER_NEW",0);//000

define("USER_NORMAL",1);//001

define("USER_ADVANCE",2);//010

define("USER_MANAGE",3);//011

define("USER_SUPER",4);//100

define("USER_MASK",7);//111

define("GENDER_UNKNOWN",0);// 000000

define("GENDER_MALE",8);// 001000

define("GENDER_FEMALE",9);// 010000

define("GENDER_MASK",56);// 111000

如果我们要查询所有 男用户 则:

$status=GENDER_MALE;

$mask=GENDER_MASK;

$sql="select * from binary_sample where status & ${mask}' = ${status}";

如果我们要查询所有 管理员用户 则:

$status=USER_MANAGE;

$mask=USER_MASK;

$sql="select * from binary_sample where status & ${mask}' = ${status}";

如果我们要查询所有 男管理员用户 则:

$status=GENDER_MALE & USER_MANAGE;

$mask = GENDER_MASK & GENDER_MASK;

$sql="select * from binary_sample where status & ${mask}' = ${status}";

如果我们要查询所有 非 新注册未被批准用户 则:

$status = USER_NEW;

$mask = USER_MASK;

$sql="select * from binary_sample where status & ${mask} != ${status}";

依此类推,只要定义好每个值的含义,查询基本上就定了。

PHP 相关文章推荐
PHP与javascript对多项选择的处理
Oct 09 PHP
php 遍历数据表数据并列表横向排列的代码
Sep 05 PHP
PHP中文URL编解码(urlencode()rawurlencode()
Jul 03 PHP
PHP 图片水印类代码
Aug 27 PHP
php获取域名的google收录示例
Mar 24 PHP
windows7下安装php的php-ssh2扩展教程
Jul 04 PHP
php实现的mongodb操作类实例
Apr 03 PHP
PHP网站建设的流程与步骤分享
Sep 25 PHP
php防止用户重复提交表单
Nov 02 PHP
[原创]PHP简单开启curl的方法(测试可行)
Jan 11 PHP
PHP简单获取网站百度搜索和搜狗搜索收录量的方法
Aug 23 PHP
Laravel服务容器绑定的几种方法总结
Jun 14 PHP
PHP查询MySQL大量数据的时候内存占用分析
Jul 22 #PHP
PHP性能优化 产生高度优化代码
Jul 22 #PHP
PHP多个版本的分析解释
Jul 21 #PHP
QQ登录 PHP OAuth示例代码
Jul 20 #PHP
模板引擎正则表达式调试小技巧
Jul 20 #PHP
php中批量替换文件名的实现代码
Jul 20 #PHP
关于php连接mssql:pdo odbc sql server
Jul 20 #PHP
You might like
rephactor 优秀的PHP的重构工具
2011/06/09 PHP
PHP中is_file()函数使用指南
2015/05/08 PHP
基于PHP实现微信小程序客服消息功能
2019/08/12 PHP
$()JS小技巧
2007/07/21 Javascript
javascript下利用arguments实现string.format函数
2010/08/24 Javascript
javascript中的注释使用与注意事项小结
2011/09/20 Javascript
jquery validate在ie8下的bug解决方法
2013/11/13 Javascript
JS表的模拟方法
2015/02/05 Javascript
JavaScript实现的一个倒计时的类
2015/03/12 Javascript
自定义jQuery插件方式实现强制对象重绘的方法
2015/03/23 Javascript
js获取url传值的方法
2015/12/18 Javascript
用JS实现图片轮播效果代码(一)
2016/06/26 Javascript
jQuery DateTimePicker 日期和时间插件示例
2017/01/22 Javascript
async/await与promise(nodejs中的异步操作问题)
2017/03/03 NodeJs
解决layui checkbox 提交多个值的问题
2019/09/02 Javascript
基于JQuery和DWR实现异步数据传递
2020/10/16 jQuery
利用 Chrome Dev Tools 进行页面性能分析的步骤说明(前端性能优化)
2021/02/24 Javascript
python求素数示例分享
2014/02/16 Python
Python操作csv文件实例详解
2017/07/31 Python
python中正则表达式的使用方法
2018/02/25 Python
TensorFlow实现RNN循环神经网络
2018/02/28 Python
Python中的Numpy矩阵操作
2018/08/12 Python
python for循环remove同一个list过程解析
2019/08/14 Python
用Python写一个自动木马程序
2019/09/17 Python
python 采用paramiko 远程执行命令及报错解决
2019/10/21 Python
python银行系统实现源码
2019/10/25 Python
Python实现线性插值和三次样条插值的示例代码
2019/11/13 Python
Python实现图片识别加翻译功能
2019/12/26 Python
python  ceiling divide 除法向上取整(或小数向上取整)的实例
2019/12/27 Python
Python实现迪杰斯特拉算法并生成最短路径的示例代码
2020/12/01 Python
香港演唱会订票网站:StubHub香港
2019/10/10 全球购物
文秘专业个人求职信
2013/12/22 职场文书
2014年社区庆元旦活动方案
2014/03/08 职场文书
中学校庆方案
2014/03/17 职场文书
如何利用 CSS Overview 面板重构优化你的网站
2021/10/24 HTML / CSS
HttpClient实现表单提交上传文件
2022/08/14 Java/Android