源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

DB2中REVERSE函数的实现方法

  • 时间:2022-08-27 19:46 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:DB2中REVERSE函数的实现方法
[b]ORACLE:[/b] 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。 [b]sql server:[/b] [img]http://files.jb51.net/file_images/article/201602/20160214115222.png[/img] 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 DATA
BEGIN

 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
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部