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&java(三)
Oct 09 PHP
php懒人函数 自动添加数据
Jun 28 PHP
php报表之jpgraph柱状图实例代码
Aug 22 PHP
discuz免激活同步登入代码修改方法(discuz同步登录)
Dec 24 PHP
Windows下的PHP安装pear教程
Oct 24 PHP
php数组索引与键值操作技巧实例分析
Jun 24 PHP
PHP导入导出Excel代码
Jul 07 PHP
php 伪造HTTP_REFERER页面URL来源的三种方法
Sep 22 PHP
laravel 5异常错误:FatalErrorException in Handler.php line 38的解决
Oct 12 PHP
PHP双向链表定义与用法示例
Jan 31 PHP
PHP保留两位小数的几种方法
Jul 24 PHP
浅谈laravel-admin form中的数据,在提交后,保存前,获取并进行编辑
Oct 21 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
PHP 存取 MySQL 数据库的一个例子
2006/10/09 PHP
yii实现使用CUploadedFile上传文件的方法
2015/12/28 PHP
php数组函数array_walk用法示例
2016/05/26 PHP
微信自定义分享php代码分析
2016/11/24 PHP
PHP对象的浅复制与深复制的实例详解
2017/10/26 PHP
判断浏览器的javascript版本的代码
2010/09/03 Javascript
JQuery+DIV自定义滚动条样式的具体实现
2013/06/25 Javascript
ECMAScript6中Map/WeakMap详解
2015/06/12 Javascript
JS中递归函数
2016/06/17 Javascript
JavaScript实现页面无操作倒计时退出
2016/10/22 Javascript
canvas学习之API整理笔记(一)
2016/12/29 Javascript
JavaScript中的子窗口与父窗口的互相调用问题
2017/02/08 Javascript
微信小程序 下拉菜单简单实例
2017/04/13 Javascript
通过学习bootstrop导航条学会修改bootstrop颜色基调
2017/06/11 Javascript
element 结合vue 在表单验证时有值却提示错误的解决办法
2018/01/22 Javascript
vue-cli扩展多模块打包的示例代码
2018/04/09 Javascript
简述ES6新增关键字let与var的区别
2019/08/23 Javascript
vue项目引入ts步骤(小结)
2019/10/31 Javascript
原生js实现二级联动菜单
2019/11/27 Javascript
基于leaflet.js实现修改地图主题样式的流程分析
2020/05/15 Javascript
深入了解Vue.js 混入(mixins)
2020/07/23 Javascript
使用纯前端JavaScript实现Excel导入导出方法过程详解
2020/08/07 Javascript
JavaScript检测是否开启了控制台(F12调试工具)
2020/10/02 Javascript
python文件读写操作与linux shell变量命令交互执行的方法
2015/01/14 Python
Python实现的远程登录windows系统功能示例
2018/06/21 Python
Python判断一个三位数是否为水仙花数的示例
2018/11/13 Python
Python字符串的全排列算法实例详解
2019/01/07 Python
移动端Web页面的CSS3 flex布局快速上手指南
2016/05/31 HTML / CSS
美国孕妇装购物网站:Motherhood Maternity
2019/09/22 全球购物
高级销售员求职信
2013/10/25 职场文书
出纳员岗位职责风险
2014/03/06 职场文书
2014年征兵标语
2014/06/20 职场文书
党员批评与自我批评发言材料
2014/10/14 职场文书
团代会闭幕词
2015/01/28 职场文书
停电通知范文
2015/04/16 职场文书
2015年超市员工工作总结
2015/05/04 职场文书