澳门皇冠金沙网站-澳门皇冠844网站

热门关键词: 澳门皇冠金沙网站,澳门皇冠844网站

皇冠手机网页位运算举例权限应用,基本语言元

摘要:

  • 标准sql语言是不区分大小写的

二进制里的最简单的运算

不是加,也不是减,而是位移,即将数字水平向左或者向右进行移动,在数学里的实际意义就是乘以2和除以2,对于每种高级程序设计来说都有自己的位运算符,大多部都使用<<和>>来表示,对于位运算,它有自己的实际意义,对于自然数字2来说,它的实际意义是什么呢?让我们来一起看一下。

--例:
--权限表如下:
create table userRole(userId varchar(36),
roleInfo int);
go

insert into userRole(userId,roleInfo)values('test',1) ---初始化测试账号"test",拥有查看权限
insert into userRole(userId,roleInfo)values('猫猫',2) 
--当我们需要给用户加入修改"2"权限,则可以使用以下运算
update userRole set roleInfo =roleInfo|2 where userId ='test'


--当我们需要给用户加入导出"4"权限,则可以继续使用以下运算
update userRole set roleInfo =roleInfo|4 where userId ='test'


--当我们需要给用户删除导出"4"权限,则可以继续使用以下运算
--删除权限前需判断用户是否存在此权限,此脚本不可多次运行
--if exists (select null from userRole where roleInfo &4 =4 and userId ='test')
---begin
update userRole set roleInfo =roleInfo^4 where userId ='test' and roleInfo&4 =4 
--end
---我们检索所有拥有权限"修改2"的用户信息
select * from userRole where roleInfo &2 = 2

go
truncate table userRole
drop table userRole

 

实际意义

这个有点像杨辉三角的东西在我们平时开发时经常会用到,因为对于这些结果都只有唯一的结合,我们如果把每位代表一种权限,那么,可以把这些结果代表这些权限的组合,这确实很有意思,而在这些组合里,我们也可以查找哪些元素(权限)不在某个结果之内,这些都可以使用位移运算实现。

    /// <summary>
        /// 从位集合中找到空位
        /// </summary>
        /// <param name="max"></param>
        /// <param name="he"></param>
        /// <returns></returns>
        long GetValidNumber(long he)
        {
            for (long i = 1; i < he; i = i << 1)
            {
                if ((he & i) != i)
                    return i;
            }
            return 0;
        }

大叔曾经也对一些聚合运算进行了扩展,对sum,count这些聚集来说,位运算是不适合的,如果我们希望对一个集合进行按运求和(或),如何去实现了,.net基础类库没有这种方式,所以,大叔对它进行了扩展,代码如下

      /// <summary>
        /// 按或进行位运算
        /// 作者:仓储大叔
        /// </summary>
        /// <typeparam name="TSource"></typeparam>
        /// <param name="source"></param>
        /// <param name="selector"></param>
        /// <returns></returns>
        public static long BinaryOr<TSource>(this IEnumerable<TSource> source, Func<TSource, long> selector)
        {
            long result = 0;
            foreach (var item in source)
            {
                result |= selector(item);
            }
            return result;
        }

对于上面的位移运算来说,它们的实现意义在大叔的权限体系里得到了完美的体现,我们可以看一下数据表的设计,使用Flag来设计授权按钮,即每种按钮都有唯一的位标识,而它们可以相互组合!

皇冠手机网页 1

授权按钮组件的结果

皇冠手机网页 2

对于角色授权时,你可以将多种按钮组合授权,而使用一个字段来存储位运算的结果即可,无论从效率还是操作上,都比拼字符串和关系表来的更容易!

皇冠手机网页 3

本代码选自《Lind.DDD.Manager》相关代码和程序的截图!

感谢各位的阅读!

回到目录

 

  • 比较运算符:大小写区分问题,尾随空白处理问题
  • 逻辑运算符:sqlserver支持的运算符比sybase多很多如:some、any、all、in、between、exists、like、in,但是不支持is;sysbase只支持:and 、or 、not、is
  • 位运算符:
  • 字符串连接运算符:sysbase除了支持 “ ”外,还支持 sql2003标准的“||”;sqlserver不支持该操作符

自然数据2的奥秘

十进制:2,对应二进制的10

位移运算的结果

皇冠手机网页 4

对上面的结果,我们可以看到2的位移运算刚好是2的N次幂,这个确实很有意思,但还不是最有意思的,对于数字来说还有一些位运算,下面我们来看一下图示。

皇冠手机网页 5

我们看一下2的指数,分别是1到10在,而它的幂我们是否很熟悉,这在计算机设置里经常可以看到,你的内存,硬盘,U盘,显卡上的存储存量应该都有它们的身影,我们可以试着把这些幂进行按位取或,看一下结果

1 | 2=3

1 | 2 | 4=7

1 | 2 | 4 | 8=15

1 | 2 | 4 | 8 | 16 =31

1 | 2 | 4 | 8 | 16 | 32=127

注意事项:

null值问题:

回到目录


 

进制

我是一个程序猿,我喜欢简单的数字,十进制如何,数字太多,有10种数字组成,但由于它广为人知,所有使用最为广泛,人们的惯性思维培养了十进制,并说它是最容易被计算的数字,事实上,在计算机里,最简单的进制是当然是二进制,原因最为直接,因为它只有两种数字,0和1。

下文通过举例的方式讲述sqlserver中位运算的相关知识,如下所示:
实验环境:sqlserver 2008 R2

  • 二进制或十六进制字符串常量:以“0x”开头(不知道是否区分大小写?待验证?),偶数个[0-9a-f]字符组成的不带引号的字符串序列。

在sqlserver的权限设置,我们通常使用1、2、4、8、16、32、64、128等数值分别表示相关信息的某一状态供业务状态使用,通过字段值之间的组合形成一个状态值存储到数据库中,
设置一个角色拥有的权限
例:
1:代表“查看”按钮权限
2:代表"修改"按钮
4:代表"导出"按钮
8:代表"删除"按钮
...

以上sybase和sqlserver是完全相同的!!

 

  • sybase   表达式:常量、列名、函数、    变量、    一元运算、两元运算、组合运算、仅仅返回一个标量值的子查询、case表达式、if表达式、特殊值(类似于sqlserver的全局系统变量或系统函数)
  • sqlserver表达式:常量、列名、标量函数、本地变量、一元运算、两元运算、组合运算、仅仅返回一个标量值的子查询、case表达式、is [not] null表达式

此处权限设置,主要使用二进制中每一位代表一个权限及位运算的特性进行权限的增减操作
由于"^异或运算"运算,左表达式1或0 时 右表达式为1时,将分别产生 0、1,所以剔除权限时,一定要判断是否存在此权限
 转自:http://www.maomao365.com/?p=7137

  • sybase中只能用于where、having、check、on短语、if表达式中的,类似于sqlserver的其他逻辑操作符和比较操作符,有:二元比较运算、{any|some|all}(多行子查询) 、between、like ? escape ?、in、exists、not、and、or、is [NOT] {NULL|TRUE|FALSE|UNKNOWN}、显示选择性估计
  • sybase基本上这些搜索条件运算和sqlserver中相同;不同处:like 运算支持escape是sybase的特性;增强了is 测试的能力

 

 

运算符:

本文由澳门皇冠金沙网站发布于数据库研究,转载请注明出处:皇冠手机网页位运算举例权限应用,基本语言元