Welcome 微信登录

首页 / 数据库 / MySQL / DB2中REVERSE函数的实现

有哥们在群里问DB2有没有自带的reverse函数,我测试一下,DB2确实内置该函数,但是Oracle,sql server都内置了该函数,来看一下ORACLE:SQL> select reverse("1234") from dual;REVERSE(
--------
4321SQL> 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"))
-----------------------
                      8SQL> select reverse("1234    ") from dual;REVERSE("1234")
----------------
    4321如果返回类型是varchar,长度应该是4,所以返回值是char。参数类型也应该是是char。sql server:DB2中REVERSE函数的实现reverse函数的参数类型varchar或nvarchar,返回类型也是varchar或nvarcharC:>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;654321select reverse(1234) from dual;  --看执行计划,应该可以看到类型转换4321本文永久更新链接地址