我是靠谱客的博主 温柔小松鼠,最近开发中收集的这篇文章主要介绍Oracle如何&操作进行二进制的比对,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Oracle 中 bitand() 函数
返回两个数值型数值在按位进行 AND 运算后的结果。
语法
BITAND(nExpression1, nExpression2)
参数
nExpression1, nExpression2

指定按位进行 AND 运算的两个数值。如果 nExpression1 和 nExpression2 为非整数型,那么它们在按位进行 AND 运算之前转换为整数。
说明
BITAND( ) 将 nExpression1 的每一位同 nExpression2 的相应位进行比较。如果 nExpression1 和 nExpression2 的位都是 1,相应的结果位就是 1;否则相应的结果位是 0。

下表列出对 nExpression1 和 nExpression2 按位进行 AND 运算的结果:

nExpression1 位 nExpression2 位 结果位
0 0 0
0 1 0
1 1 1
1 0 0
bitand( ) 函数示例
x = 5 && 二进制为 0101
y = 6 && 二进制为 0110
? bitand(x,y) && 返回值 4,二进制为 0100

select * from ppm_taskinfo t where to_number(bitand(t.taskstatus,2097152)) > 0 ;

ORACLE中的BITOR和BITXOR
ORACLE中只有BITAND而没有BITOR, BITXOR

原因是,有了BITAND, 很容易实现BITOR和BITXOR

BITOR(x,y) = (x + y) - BITAND(x, y);

BITXOR(x,y) = BITOR(x,y) - BITAND(x,y) = (x + y) - BITAND(x, y) * 2;

hextoraw是一个用十六进制转换的函数,所以hextoraw(13)实际是
十六进制:13
十进制:19(16+3)
二进制:10011

hextoraw(2)的二进制为10
所以
select utl_raw.bit_and(hextoraw(13),hextoraw(2)) from dual
=select bitand(19,2) from dual

=(10011) and (10)=(11) and (10)=(10)=’02’

注: 根据说明utl_raw.bit_and与bitand的不同是utl_raw.bit_and在将两个数字转换为二进制后,会忽略掉多余的位数.

最后

以上就是温柔小松鼠为你收集整理的Oracle如何&操作进行二进制的比对的全部内容,希望文章能够帮你解决Oracle如何&操作进行二进制的比对所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(43)

评论列表共有 0 条评论

立即
投稿
返回
顶部