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 相关文章推荐
Uchome1.2 1.5 代码学习 common.php
Apr 24 PHP
PHP 程序授权验证开发思路
Jul 09 PHP
php数组函数序列 之shuffle()和array_rand() 随机函数使用介绍
Oct 29 PHP
PHP常用特殊运算符号和函数总结(php新手入门必看)
Feb 02 PHP
Yii PHP Framework实用入门教程(详细介绍)
Jun 18 PHP
php将文本文件转换csv输出的方法
Dec 31 PHP
php 7新特性之类型申明详解
Jun 06 PHP
PHP实现的redis主从数据库状态检测功能示例
Jul 20 PHP
使用PHP+MySql+Ajax+jQuery实现省市区三级联动功能示例
Sep 15 PHP
PHP通过get方法获得form表单数据方法总结
Sep 12 PHP
TP5框架实现的数据库备份功能示例
Apr 05 PHP
PHP设计模式(七)组合模式Composite实例详解【结构型】
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 XPath对XML文件查找及修改实现代码
2011/07/27 PHP
php调用google接口生成二维码示例
2014/04/28 PHP
Laravel5.7 Eloquent ORM快速入门详解
2019/04/12 PHP
Yii框架视图、视图布局、视图数据块操作示例
2019/10/14 PHP
PHP常用函数之base64图片上传功能详解
2019/10/21 PHP
JavaScript中的其他对象
2008/01/16 Javascript
汉化英文版的Dreamweaver CS5并自动提示jquery
2010/11/25 Javascript
extjs中grid中嵌入动态combobox的应用
2011/01/01 Javascript
NodeJS的模块写法入门(实例代码)
2012/03/07 NodeJs
JS判断页面加载状态以及添加遮罩和缓冲动画的代码
2012/10/11 Javascript
JS完成代码前最好对其做5件事
2013/04/07 Javascript
JS中setInterval、setTimeout不能传递带参数的函数的解决方案
2013/04/28 Javascript
Javascript的闭包详解
2014/12/26 Javascript
JavaScript数组随机排列实现随机洗牌功能
2015/03/19 Javascript
Radio 单选JS动态添加的选项onchange事件无效的解决方法
2016/12/12 Javascript
Angularjs自定义指令实现分页插件(DEMO)
2017/09/16 Javascript
基于webpack 实用配置方法总结
2017/09/28 Javascript
jQuery+koa2实现简单的Ajax请求的示例
2018/03/06 jQuery
详解python中的文件与目录操作
2017/07/11 Python
python3 unicode列表转换为中文的实例
2018/10/26 Python
python实现n个数中选出m个数的方法
2018/11/13 Python
Python使用指定字符长度切分数据示例
2019/12/05 Python
Pytorch实现LSTM和GRU示例
2020/01/14 Python
纯CSS3单页切换导航菜单界面设计的简单实现
2016/08/16 HTML / CSS
HTML5之web workers_动力节点Java学院整理
2017/07/17 HTML / CSS
Dune London官网:英国著名奢华鞋履品牌
2017/11/30 全球购物
Roxy荷兰官方网站:冲浪、滑雪板、服装和配件
2019/10/22 全球购物
大学生收银员求职信分享
2014/01/02 职场文书
2014年五四青年节活动策划书
2014/04/22 职场文书
森林防火宣传标语
2014/06/27 职场文书
学校教师读书活动总结
2014/07/08 职场文书
师德标兵事迹材料
2014/12/19 职场文书
银行求职信范文怎么写
2015/03/20 职场文书
Go缓冲channel和非缓冲channel的区别说明
2021/04/25 Golang
golang elasticsearch Client的使用详解
2021/05/05 Golang
使用tensorflow 实现反向传播求导
2021/05/26 Python