• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    DB2中REVERSE函数的实现方法

    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死锁的解决过程全记录
    下一篇:使用SQL Server连接服务器访问DB2 Server
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

    DB2中REVERSE函数的实现方法 DB2,中,REVERSE,函数,的,实现,