DB2中REVERSE函数的实现方法
数据库  /  管理员 发布于 5年前   228
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 DATABEGIN 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
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号