DB2中REVERSE函數(shù)的實(shí)現(xiàn)方法
ORACLE:
SQL> select reverse("1234") from dual;
REVERSE(
--------
4321
SQL> select reverse(12121) from dual;
select reverse(12121) from dual
*
第 1 行出現(xiàn)錯(cuò)誤:
ORA-00932: 數(shù)據(jù)類型不一致: 應(yīng)為 CHAR, 但卻獲得 NUMBER
說(shuō)明oracle中reverse的參數(shù)是char類型,返回值也是char,到底是不是這樣,我們來(lái)驗(yàn)證一下
SQL> select length(reverse("1234 ")) from dual;
LENGTH(REVERSE("1234"))
-----------------------
8
SQL> select reverse("1234 ") from dual;
REVERSE("1234")
----------------
4321
如果返回類型是varchar,長(zhǎng)度應(yīng)該是4,所以返回值是char。參數(shù)類型也應(yīng)該是是char。
sql server:
reverse函數(shù)的參數(shù)類型varchar或nvarchar,返回類型也是varchar或nvarchar
C:\>sqlcmd -S kermart -U sa -P sa -d master
1> select reverse("1234");
2> go
----
4321
(1 行受影響)
1> select reverse(1234); --發(fā)生類型轉(zhuǎn)換,應(yīng)該可以從執(zhí)行計(jì)劃中看出來(lái)
2> go
------------
4321
(1 行受影響)
基于oracle,sql server都內(nèi)置了reverse函數(shù),DB2也應(yīng)該有它的reverse函數(shù),因?yàn)橛幸欢ǖ膽?yīng)用場(chǎng)景。
CREATE OR REPLACE FUNCTION REVERSE( p1 varchar(200)) RETURNS VARCHAR(200) SPECIFIC "REVERSE" LANGUAGE SQL DETERMINISTIC NO EXTERNAL ACTION READS SQL DATABEGIN declare v_str varchar(100) default ""; DECLARE v_index INTEGER; --定義下標(biāo) SET v_index = length(p1); WHILE(v_index >= 1) DO SET v_str = v_str||substr(p1,v_index,1); SET v_index = v_index - 1; END WHILE; return v_str;END@
測(cè)試一下
select reverse("123456") from dual;
654321
select reverse(1234) from dual; --看執(zhí)行計(jì)劃,應(yīng)該可以看到類型轉(zhuǎn)換
4321
相關(guān)文章:
1. DB2中的數(shù)據(jù)值加密(1)2. DB2中多種常用功能的解決方法(1)3. Db2數(shù)據(jù)庫(kù)中常見(jiàn)的堵塞問(wèn)題分析與處理方法4. DB2 9的九大新特性5. 國(guó)內(nèi)學(xué)院派專家對(duì)DB2 9新產(chǎn)品贊不絕口6. DB2用戶定義函數(shù)實(shí)現(xiàn)多種語(yǔ)言的排序7. 帶你深入了解IBM DB2數(shù)據(jù)庫(kù)的備份與恢復(fù)8. 輕松解決IBM DB2數(shù)據(jù)庫(kù)定位鎖等待問(wèn)題9. 詳細(xì)講解IBM DB2數(shù)據(jù)庫(kù)無(wú)限活動(dòng)日志策略10. 高手教你用VCS配置DB2雙機(jī)-高級(jí)(1)
