DB2

推荐列表 站点导航

当前位置:首页 > 数据库 > DB2 >

DB2中REVERSE函数的实现方法

来源:互联网  作者:网友投稿  发布时间:2021-01-08 20:42
有哥们在群里问DB2有没有自带的reverse函数,我测试一下,DB2确实内置该函数,但是oracle,sql server都内置了该函数,来...

有哥们在群里问DB2有没有自带的reverse函数,我测试一下,DB2确实内置该函数,但是oracle,sql server都内置了该函数,来看一下

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

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

 

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; --看执行计划,应该可以看到类型转换

相关热词:

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!

本文地址: https://v30.fanwenzhu.com/sql/db2/12064.shtml

Copyright © www.juheyunku.com      关于 | 合作 | 声明 | 联系 | 更新 | 地图 | Tags

DB2中REVERSE函数的实现方法

2021-01-08 编辑:网友投稿

有哥们在群里问DB2有没有自带的reverse函数,我测试一下,DB2确实内置该函数,但是oracle,sql server都内置了该函数,来看一下

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

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

 

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; --看执行计划,应该可以看到类型转换

本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供学习参考!
本文地址为 https://v30.fanwenzhu.com/sql/db2/12064.shtml

相关文章

风云图片

推荐阅读

返回DB2频道首页