DB2中REVERSE函数的实现方法

所属分类: 数据库 / DB2 阅读数: 188
收藏 0 赞 0 分享

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 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

更多精彩内容其他人还在看

DB2中的数据移动(一)

DB2中的数据移动(一)
收藏 0 赞 0 分享

DB2大事记

DB2大事记
收藏 0 赞 0 分享

DB2编程序技巧(1)

DB2编程序技巧(1)
收藏 0 赞 0 分享

创建一个空的IBM DB2 ECO数据库的方法

创建一个空的IBM DB2 ECO数据库的方法
收藏 0 赞 0 分享

DB2 日期和时间的函数应用说明

DB2中有关日期和时间的函数,及应用,比较老的文章了,需要的朋友可以参考下。
收藏 0 赞 0 分享

DB2 常用命令速查(备忘)

DB2 常用命令速查,需要的朋友可以参考下。
收藏 0 赞 0 分享

DB2 常用命令小结

DB2 常用命令,对于使用db2的朋友可以参考下。
收藏 0 赞 0 分享

DB2 自动递增字段实现方法

DB2提供了当有一行插入的时候自动在某一列添加值的功能,可以使用所谓identity rules,简单点的比如某个数值的递增填入该列中,当然也有很复杂的。
收藏 0 赞 0 分享

DB2比较常用与实用sql语句总结

DB2比较常用与实用sql语句总结,学习与使用db2朋友可以参考下。
收藏 0 赞 0 分享

DB2 SELECT语句高级用法

DB2 SELECT语句高级用法,学习db2的朋友可以参考下。
收藏 0 赞 0 分享
查看更多