DB2中REVERSE函数的实现方法(db2 revoke)居然可以这样

随心笔谈9个月前更新 admin
202 00
🌐 经济型:买域名、轻量云服务器、用途:游戏 网站等 《腾讯云》特点:特价机便宜 适合初学者用 点我优惠购买
🚀 拓展型:买域名、轻量云服务器、用途:游戏 网站等 《阿里云》特点:中档服务器便宜 域名备案事多 点我优惠购买
🛡️ 稳定型:买域名、轻量云服务器、用途:游戏 网站等 《西部数码》 特点:比上两家略贵但是稳定性超好事也少 点我优惠购买

文章摘要

文章主要介绍了ORACLE和SQL Server中`REVERSE`函数的使用方法及其参数类型。在ORACLE中,`REVERSE`函数的参数和返回类型为`CHAR`或`VARCHAR`,而SQL Server的`REVERSE`函数参数和返回类型为`VARCHAR`或`NVARCHAR`,无需进行类型转换。文章还展示了ORACLE中自定义实现`REVERSE`函数的代码,并通过示例验证了其正确性。通过对比,文章强调了ORACLE和SQL Server在`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

© 版权声明

相关文章