搜索
首页数据库mysql教程数据库字段复用的基本原理与示例_MySQL

bitsCN.com

  一、逻辑代数基础:

  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}";

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

bitsCN.com
声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
MySQL:字符串数据类型可用哪些字符集?MySQL:字符串数据类型可用哪些字符集?May 10, 2025 am 12:07 AM

mysqloffersvariouscharactersetsforstringdatatypes:1)latin1 forwesterneuropeanlanguages,2)utf8 formultingualsupport,3)utf8mb4f OREXTEDENDENDENENICODECLUDINGEMOJIS,4)UCS2FORIXED-WIDTHENCODING,5)assiiforbasiclatin.ChoosideStherightStetSetensensersdaintegrity

mysql:斑点流比存储它们更好吗?mysql:斑点流比存储它们更好吗?May 10, 2025 am 12:06 AM

流式传输BLOB确实比直接存储更好,因为它能减少内存使用和提高性能。1)通过逐步读取和处理文件,避免了数据库膨胀和性能下降。2)流式传输需要更复杂的代码逻辑,且可能增加I/O操作次数。

MySQL字符串类型:存储,性能和最佳实践MySQL字符串类型:存储,性能和最佳实践May 10, 2025 am 12:02 AM

mySqlStringTypesimpactStorageAndPerformanCeaseAsfollows:1)长度,始终使用theSamestoragespace,whatcanbefasterbutlessspace-felfficity.2)varCharisvariable varcharisvariable length,morespace-morespace-morespace-effficitybuteftife buteftife butfority butfority textifforlyslower.3)

了解MySQL字符串类型:VARCHAR,文本,char等了解MySQL字符串类型:VARCHAR,文本,char等May 10, 2025 am 12:02 AM

mySqlStringTypesIncludeVarChar,文本,char,enum和set.1)varCharisVersAtileForvariable-lengthStringStringSuptOptoPeptoPepecifientlimit.2)textisidealforlargetStortStorStoverStorextorewiteWithoutAdefinedLengthl.3)charlisfixed-Length

MySQL中的字符串数据类型是什么?MySQL中的字符串数据类型是什么?May 10, 2025 am 12:01 AM

MySQLoffersvariousstringdatatypes:1)CHARforfixed-lengthstrings,2)VARCHARforvariable-lengthtext,3)BINARYandVARBINARYforbinarydata,4)BLOBandTEXTforlargedata,and5)ENUMandSETforcontrolledinput.Eachtypehasspecificusesandperformancecharacteristics,sochoose

如何向新的MySQL用户授予权限如何向新的MySQL用户授予权限May 09, 2025 am 12:16 AM

TograntpermissionstonewMySQLusers,followthesesteps:1)AccessMySQLasauserwithsufficientprivileges,2)CreateanewuserwiththeCREATEUSERcommand,3)UsetheGRANTcommandtospecifypermissionslikeSELECT,INSERT,UPDATE,orALLPRIVILEGESonspecificdatabasesortables,and4)

如何在MySQL中添加用户:逐步指南如何在MySQL中添加用户:逐步指南May 09, 2025 am 12:14 AM

toadduserInmysqleffectection andsecrely,theTheSepsps:1)USEtheCreateuserStattoDaneWuser,指定thehostandastrongpassword.2)GrantNectalRevileSaryPrivilegesSustate,usiveleanttatement,AdheringTotheTeprinciplelastPrevilegege.3)

mysql:添加具有复杂权限的新用户mysql:添加具有复杂权限的新用户May 09, 2025 am 12:09 AM

toaddanewuserwithcomplexpermissionsinmysql,loldtheSesteps:1)创建eTheEserWithCreateuser'newuser'newuser'@''localhost'Indedify'pa ssword';。2)GrantreadAccesstoalltablesin'mydatabase'withGrantSelectOnMyDatabase.to'newuser'@'localhost';。3)GrantWriteAccessto'

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能

MinGW - 适用于 Windows 的极简 GNU

MinGW - 适用于 Windows 的极简 GNU

这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境