亚洲综合社区欧美综合色-欧美逼逼一区二区三区-国产老熟女高潮精品网站-国产日韩最新视频在线看

始創(chuàng)于2000年 股票代碼:831685
咨詢熱線:0371-60135900 注冊有禮 登錄
  • 掛牌上市企業(yè)
  • 60秒人工響應(yīng)
  • 99.99%連通率
  • 7*24h人工
  • 故障100倍補償
全部產(chǎn)品
您的位置: 網(wǎng)站首頁 > 幫助中心>文章內(nèi)容

巧用SQL語句完成位操作

發(fā)布時間:  2012/8/3 17:26:50
數(shù)據(jù)庫中,有些字段其值是按位表示的,即不同的位有不同的含義,比如用不同的位代表用戶的不同權(quán)限或?qū)傩裕撐粸?時,表示用戶有此權(quán)限或?qū)傩,?則無此權(quán)限或?qū)傩缘。相信有很多?shù)據(jù)庫為了效率也有類似的設(shè)計。
    在C語言中提供了&, |, ~以及>>,
1. func_bitoper
    我們在工作中常常有這樣的需求,要求將某個字段的某一位或多位置為1或0,輸入?yún)?shù)in_value是待處理的值,enable_mask表示要將哪幾位置為1,如要將bit0和bit2置為1,則enable_mask := POWER(2,0) + POWER(2,2); ,enable_mask為0表示沒有需要置為1的位,同理disable_mask表示要將哪幾位置為0,如要將bit1和bit3置為0,則disable_mask := POWER(2,1) + POWER(2,3); ,disable_mask為0表示沒有需要置為0的位, 返回值為經(jīng)過位操作后的值。
    換句話說,enable動作相當于與enable_mask進行或操作,disable動作相當于與~disable_mask進行與操作。
create or replace function func_bitoper(in_value IN NUMBER,enable_mask IN NUMBER,
       disable_mask IN NUMBER ) return NUMBER IS
 
 l_enable    number;
 l_disable   number;
 i           number;
 j           number;
 l_outvalue  number;
 l_temp      number;
begin
 l_enable   := enable_mask;
 l_disable  := disable_mask;
 l_outvalue := in_value;
 
 -- enable
 j := 0;
 while l_enable > 0 loop
  
   if MOD(l_enable,2) = 1 then              -- to do set work
      l_temp :=TRUNC(l_outvalue/POWER(2,j));
      if MOD (l_temp,2) = 0 then            -- set it to 1
         l_outvalue := l_outvalue + POWER(2,j);
      end if; 
   end if;
   l_enable := TRUNC(l_enable/2);
   j := j+1 ;
 end loop;
 -- disable
 j := 0;
 while l_disable > 0 loop
  
   if MOD(l_disable,2) = 1 then              -- to do set work
      l_temp :=TRUNC(l_outvalue/POWER(2,j));
      if MOD (l_temp,2) = 1 then            -- set it to 0
         l_outvalue := l_outvalue - POWER(2,j);
      end if; 
   end if;
   l_disable := TRUNC(l_disable/2);
   j := j+1 ;
 end loop;
 return l_outvalue;
end;
/
2. func_and
   用于對兩個數(shù)進行與操作,經(jīng)常用于判斷用戶是否有權(quán)限等。
create or replace function func_and(in_value IN NUMBER,in_mask IN NUMBER)
  return number is
  i        number;
  n_result number;
  n_value number;
  n_mask  number;
begin
 n_value := in_value;
 n_mask  := in_mask;
 i := 0;
 n_result := n_value;
 while n_value > 0 loop
   if (mod(n_mask,2) = 0) and (mod(n_value,2) = 1) then
     n_result := n_result - power(2,i);
   end if;
   n_value := TRUNC(n_value/2);
   n_mask  := TRUNC(n_mask/2);
   i := i + 1;
 end loop;
 return n_result;
end;
/

本文出自:億恩科技【1tcdy.com】

服務(wù)器租用/服務(wù)器托管中國五強!虛擬主機域名注冊頂級提供商!15年品質(zhì)保障!--億恩科技[ENKJ.COM]

  • 您可能在找
  • 億恩北京公司:
  • 經(jīng)營性ICP/ISP證:京B2-20150015
  • 億恩鄭州公司:
  • 經(jīng)營性ICP/ISP/IDC證:豫B1.B2-20060070
  • 億恩南昌公司:
  • 經(jīng)營性ICP/ISP證:贛B2-20080012
  • 服務(wù)器/云主機 24小時售后服務(wù)電話:0371-60135900
  • 虛擬主機/智能建站 24小時售后服務(wù)電話:0371-60135900
  • 專注服務(wù)器托管17年
    掃掃關(guān)注-微信公眾號
    0371-60135900
    Copyright© 1999-2019 ENKJ All Rights Reserved 億恩科技 版權(quán)所有  地址:鄭州市高新區(qū)翠竹街1號總部企業(yè)基地億恩大廈  法律顧問:河南亞太人律師事務(wù)所郝建鋒、杜慧月律師   京公網(wǎng)安備41019702002023號