日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
如何用SAS宏實現(xiàn)Oracle中的decode函數(shù)?

Oracle數(shù)據(jù)庫中的decode函數(shù)是Oracle PL/SQL的常用函數(shù)之一,那么它的用途是什么呢?接下來我們就介紹這一過程以及如何用SAS宏來實現(xiàn)Oracle數(shù)據(jù)庫中的decode功能。

創(chuàng)新互聯(lián)公司是一家專注于成都網(wǎng)站設(shè)計、網(wǎng)站建設(shè)與策劃設(shè)計,新邱網(wǎng)站建設(shè)哪家好?創(chuàng)新互聯(lián)公司做網(wǎng)站,專注于網(wǎng)站建設(shè)十載,網(wǎng)設(shè)計領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:新邱等地區(qū)。新邱做網(wǎng)站價格咨詢:028-86922220

先構(gòu)造一個例子,假設(shè)我們想給智星職員加工資,其標(biāo)準(zhǔn)是:工資在8000元以下的加20%;工資在8000元或以上的加15%,通常的做法是,先選出記錄中的工資字段值? select salary into var-salary from employee,然后對變量var-salary用if-then-else或choose case之類的流控制語句進行判斷。 如果用decode函數(shù),那么我們就可以把這些流控制語句省略,通過SQL語句就可以直接完成。

SAS宏實現(xiàn)方法:

 
 
 
  1. %macro decode /PARMBUFF;
  2. %local i count ifn valuen countall currfeild valueelse;
  3. %let countall=%sysfunc(countw(&SYSPBUFF,%quote(,)));
  4. %let count=%eval((&countall-1)/2);
  5. %let currfeild=%scan(%quote(&SYSPBUFF),1);
  6. case &currfeild 
  7. %do i=1 %to &count;
  8. %let ifn=%scan(%quote(&SYSPBUFF),%eval(&i*2));
  9. %let valuen=%scan(%quote(&SYSPBUFF),%eval(&i*2+1));
  10. when &ifn then &valuen
  11. %end;
  12. %if %eval(&countall>(&count+1)) %then %do;
  13. %let valueelse=%scan(%quote(&SYSPBUFF),&countall);
  14. else &valueelse
  15. %end;
  16. end
  17. %mend;

調(diào)用代碼如下,和oracle的調(diào)用方式和功能實現(xiàn)基本上都是一樣的。

 
 
 
  1. proc sql;
  2. create table test as 
  3. select 
  4. %decode(sex,"男",0,"女",1,2)
  5. as abc
  6. from sashelp.class;
  7. quit;

以上就是Oracle數(shù)據(jù)庫中decode函數(shù)的用途以及用SAS宏實現(xiàn)decode函數(shù)的方法,本文我們就介紹到這里了,希望本次的介紹能夠?qū)δ兴斋@!


分享題目:如何用SAS宏實現(xiàn)Oracle中的decode函數(shù)?
本文URL:http://www.5511xx.com/article/cdhhsdd.html