一起学习网 一起学习网

位运算MySQL中的位或运算及其应用(mysql位或)

MySQL的位或运算及其应用

MySQL的位或运算是一种位操作,它可以帮助开发者在MySQL数据库中将数值或位值(bitwise)操作转换为有用的结果。位或运算是MySQL的常用函数,它可以为开发者更快捷的做一些位操作,而不用去写很复杂的SQL语句。

位或运算的基本语法是:

`SELECT a|b;`

其中a和b为两个整数,可以为MySQL或ORACLE中定义的字段,根据此运算,MySQL会将两个参数a和b(也可以视作位)中,都为0的位都标记为0,而有一个为1就标记为1。只有a和b均为1时,位运算结果才为1,有一个位为1就是1。

MySQL中位运算的应用很多,最常见的就是对用户权限进行位运算,甚至可以通过位运算来存储一些相关的记录。比如在存储用户的权限时,可以将某一个用户的权限用一个数字0、1、2、4、8、16…表示,系统再通过位运算比较来判断用户是否具有某一项具体的权限,以达到快速比较用户权限的目的。

如运用MySQL位运算对用户权限进行存储及判断,具体代码如下:

1.首先定义一组用户权限:

““

#定义权限

$permissions = array(

1=>”信息发布”, //1

2=>”信息查询”, //2

4=>”营销活动”,//4

8=>”优惠促销” //8

);

““

2.将定义的权限存储到数据库中

““

#将定义的权限存储到数据库中

$user_permissions = 0; //用于保存用户的权限

foreach($permissions as $value){

if($_POST[$value] == 1){

$user_permissions= $user_permissions|$value;

}

}

$sql=”update user set permissions=’$user_permissions’ where userid=’$userid'”;

““

3.通过位运算来判断用户权限

““

#判断用户权限

$sql = “select permissions from user where userid=’$userid'”;

$result = mysql_query($sql);

$row = mysql_fetch_row($result);

$user_permissions = $row[0]

foreach($permissions as $key=>$value){

if($user_permissions & $key){

echo $value.”
“;

}

}

““

以上就是MySQL中位或运算及其应用的简单介绍,位或运算可以帮助开发者更快速的做一些位操作,它可以将值或位变换为有用的结果,比如用户权限的计算等,可以更加方便迅速的查看某一位用户的权限。