天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

php 數(shù)據(jù)庫字段復(fù)用的基本原理與示例

一、邏輯代數(shù)基礎(chǔ):
  1,數(shù)字用二進制表示,所有可能出現(xiàn)的數(shù)只有0和1兩個。
  2,基本運算只有“與”、“或”、“非”三種。
  與運算定義為:(用 & 表示與運算)
  0 & 0 = 0
  0 & 1 = 0
  1 & 0 = 0
  1 & 1 = 1
  可以簡單理解為:只要有一個0,結(jié)果就是0,和乘法類似。
  或運算定義為:(用 表示與運算)
  0 0 = 0
  0 1 = 1
  1 0 = 1
  1 1 = 1
  可以簡單理解為:只要有一個1,結(jié)果就是1,和加法類似。
  二、邏輯運算示例:
  01111010101010101111111111111111 & 1100000 = 1100000
  一般可以理解為:
  如果要獲取一個數(shù)字某N位的數(shù)值,只需要將這個數(shù)字與2的N-1次方(掩碼)進行與運算即可。
  三、數(shù)據(jù)庫字段定義:
  以數(shù)據(jù)表 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字段數(shù)據(jù)類型為32bit的整數(shù),為了盡可能的存儲多個屬性,我們將其進行如下定義:
  以下所有“位”的描述順序按照從低到高(從右到左)順序表示。
  0-2位表示用戶注冊狀態(tài):
  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技術(shù)php 數(shù)據(jù)庫字段復(fù)用的基本原理與示例,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 青青草偷拍国产亚洲欧洲 | 超嫩校花被灌醉在线观看 | GOGOGO高清在线播放韩国 | 中文字幕乱码一区AV久久 | 欧美最猛性XXXXX肛交 | 最新高清无码专区在线视频 | 久久久久毛片免费观看 | 色裕插插插影视 | 哪灬你的鸣巴好大 | 国产精品爽爽久久久久久蜜桃 | 么么哒日本影院 | 99久久综合精品免费 | 女生扒开尿口 | 办公室丝袜老师在线观看 | 你是淫荡的我的女王 | 羞羞影院午夜男女爽爽影院网站 | 国产精品嫩草影视在线观看 | 在线色av | 99re8热视频这在线视频 | 女子叉开腿让男子桶免费软件 | 亚洲日韩成人 | JK白丝校花爽到娇喘视频 | 久久婷五月综合色啪首页 | 999久久免费高清热精品 | 97人人添人人澡人人澡人人澡 | 亚洲高清有码中文字 | 少妇一夜未归暴露妓女身份 | 国产精品高清视频在线 | 男人一生要读的书 | 美女隐私黄www视频 美女议员被泄裸照 | 亚洲大片免费 | 含羞草传媒在线观看 | 国产精品私人玩物在线观看 | 在线毛片片免费观看 | 狠狠综合久久综合88亚洲 | YELLOW日本免费观看播放 | 一个人看的HD免费高清视频 | 国产亚洲精品a在线观看app | 肉肉高潮液体高干文H | 亚洲综合中文字幕无线码 | 日韩精品 中文字幕 有码 |