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 SEO优化之URL优化方法
Apr 21 PHP
php中++i 与 i++ 的区别
Aug 08 PHP
解析php如何将日志写进syslog
Jun 28 PHP
PHP JS Ip地址及域名格式检测代码
Sep 27 PHP
php获取新浪微博数据API实例
Nov 12 PHP
在PHP中使用X-SendFile头让文件下载更快
Jun 01 PHP
让codeigniter与swfupload整合的最佳解决方案
Jun 12 PHP
win7 64位系统 配置php最新版开发环境(php+Apache+mysql)
Aug 15 PHP
PHP实现检测客户端是否使用代理服务器及其匿名级别
Jan 07 PHP
PHP实现将视频转成MP4并获取视频预览图的方法
Mar 12 PHP
浅析php静态方法与非静态方法的用法区别
May 17 PHP
PHP设计模式(六)桥连模式Bridge实例详解【结构型】
May 02 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中冒号、endif、endwhile、endfor使用介绍
2010/04/28 PHP
codeigniter发送邮件并打印调试信息的方法
2015/03/21 PHP
PHP输出缓冲控制Output Control系列函数详解
2015/07/02 PHP
Laravel5.1框架路由分组用法实例分析
2020/01/04 PHP
js弹出层之1:JQuery.Boxy (二)
2011/10/06 Javascript
jquery批量控制form禁用的代码
2013/08/06 Javascript
js实现可拖动DIV的方法
2013/12/17 Javascript
jquery获取radio值实例
2014/10/16 Javascript
JavaScript组件焦点与页内锚点间传值的方法
2015/02/02 Javascript
JavaScript通过元素索引号删除数组中对应元素的方法
2015/03/18 Javascript
在jQuery中使用$而避免跟其它库产生冲突的方法
2015/08/13 Javascript
JS组件Bootstrap实现弹出框效果代码
2016/04/26 Javascript
微信小程序实战之仿android fragment可滑动底部导航栏(4)
2020/04/16 Javascript
vue+iview/elementUi实现城市多选
2019/03/28 Javascript
微信小程序实现bindtap等事件传参
2019/04/08 Javascript
vue如何截取字符串
2019/05/06 Javascript
关于vue项目中搜索节流的实现代码
2019/09/17 Javascript
layui复选框限制选择个数的方法
2019/09/18 Javascript
Python实现抓取网页生成Excel文件的方法示例
2017/08/05 Python
在CMD命令行中运行python脚本的方法
2018/05/12 Python
详解PyCharm配置Anaconda的艰难心路历程
2018/08/13 Python
python实现RabbitMQ的消息队列的示例代码
2018/11/08 Python
利用Python实现原创工具的Logo与Help
2018/12/03 Python
解决Python3 被PHP程序调用执行返回乱码的问题
2019/02/16 Python
深入了解Django View(视图系统)
2019/07/23 Python
python Matplotlib模块的使用
2020/09/16 Python
HTML5中的强制下载属性download使用实例解析
2016/05/12 HTML / CSS
LivingSocial爱尔兰:爱尔兰本地优惠
2018/08/10 全球购物
美国汽车零部件和配件网站:CarParts
2019/03/13 全球购物
官方授权图形T恤和服装:Fifth Sun
2019/06/12 全球购物
在职人员函授期间自我评价分享
2013/11/08 职场文书
考试作弊被抓检讨书
2014/10/02 职场文书
村干部任职承诺书
2015/01/21 职场文书
社区志愿服务活动感想
2015/08/07 职场文书
新学期开学寄语2016
2015/12/04 职场文书
HTML+CSS+JS实现图片的瀑布流布局的示例代码
2021/04/22 HTML / CSS