国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

DB2中REVERSE函數(shù)的實(shí)現(xiàn)方法

瀏覽:329日期:2023-03-24 09:22:28

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

標(biāo)簽: DB2
相關(guān)文章:
主站蜘蛛池模板: 六安市| 台江县| 丽江市| 涟源市| 盐山县| 游戏| 南江县| 苏州市| 涞水县| 海原县| 应城市| 衡山县| 田东县| 喀喇沁旗| 永泰县| 漳浦县| 和硕县| 自贡市| 汉川市| 囊谦县| 汤阴县| 靖远县| 资阳市| 灵台县| 光泽县| 察雅县| 绥芬河市| 清苑县| 时尚| 兴和县| 辉南县| 东乡县| 固始县| 沅陵县| 福鼎市| 屯昌县| 青冈县| 鹤峰县| 阜城县| 华坪县| 图木舒克市|