• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

    DB2中REVERSE函数的实现方法

    发布者: Error | 发布时间: 2025-6-18 12:29| 查看数: 93| 评论数: 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函数,因为有一定的应用场景。
    1. CREATE OR REPLACE FUNCTION REVERSE
    2. (
    3. p1 varchar(200)
    4. )
    5. RETURNS VARCHAR(200)
    6. SPECIFIC "REVERSE"
    7. LANGUAGE SQL
    8. DETERMINISTIC
    9. NO EXTERNAL ACTION
    10. READS SQL DATA
    11. BEGIN

    12. declare v_str varchar(100) default '';
    13. DECLARE v_index INTEGER;  --定义下标
    14. SET v_index = length(p1);
    15. WHILE(v_index >= 1) DO
    16.   SET v_str = v_str||substr(p1,v_index,1);
    17.   SET v_index = v_index - 1;
    18. END WHILE;
    19. return v_str;
    20. END@
    复制代码
    测试一下
    select reverse('123456') from dual;
    654321
    select reverse(1234) from dual; --看执行计划,应该可以看到类型转换
    4321

    来源:https://www.jb51.net/article/79395.htm
    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    ×

    最新评论

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表