国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

DB2中REVERSE函數的實現方法

瀏覽:208日期: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 行出現錯誤:
ORA-00932: 數據類型不一致: 應為 CHAR, 但卻獲得 NUMBER

說明oracle中reverse的參數是char類型,返回值也是char,到底是不是這樣,我們來驗證一下

SQL> select length(reverse("1234 ")) from dual;

LENGTH(REVERSE("1234"))
-----------------------
8

SQL> select reverse("1234 ") from dual;

REVERSE("1234")
----------------
4321

如果返回類型是varchar,長度應該是4,所以返回值是char。參數類型也應該是是char。

sql server:

reverse函數的參數類型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); --發生類型轉換,應該可以從執行計劃中看出來
2> go

------------
4321

(1 行受影響)


基于oracle,sql server都內置了reverse函數,DB2也應該有它的reverse函數,因為有一定的應用場景。

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;  --定義下標 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@

測試一下

select reverse("123456") from dual;

654321

select reverse(1234) from dual; --看執行計劃,應該可以看到類型轉換

4321

標簽: DB2
相關文章:
主站蜘蛛池模板: 国产精品欧美亚洲日本综合 | 欧美一区二区三区男人的天堂 | 国产精品成人不卡在线观看 | 欧美一级人与动毛片免费播放 | 成人午夜毛片在线看 | 99re免费99re在线视频手机版 | 日韩中文字幕免费观看 | 欧美成人免费观看的 | 一级特级毛片 | 久久久日本久久久久123 | 制服丝袜在线视频香蕉 | 99九九99九九九视频精品 | 韩国精品一区视频在线播放 | 亚洲男人天堂2017 | 国产毛片a| 国产在线观看成人 | 鲁老汉精品视频在线观看 | 精品热线九九精品视频 | 亚洲在线免费免费观看视频 | 亚洲精品国产一区二区三区四区 | 国产精品成人免费观看 | 日韩欧美在线精品 | 欧美日韩精品一区二区 | 国产成人a毛片在线 | 亚州毛片 | 亚洲综合首页 | 精品国产一区二区三区不卡在线 | 国产农村乱子伦精品视频 | 又www又黄又爽啪啪网站 | 久久影院视频 | yy6080福利午夜免费观看 | 综合欧美视频一区二区三区 | 日韩欧美在线观看 | 特级毛片www欧美 | 美国欧美一级毛片 | 国产一区二区三区久久 | 日本亚洲欧美在线 | 中文字幕亚洲不卡在线亚瑟 | 91精品欧美一区二区三区 | 全黄性高视频 | 久久黄色毛片 |