手机
当前位置:查字典教程网 >编程开发 >DB2数据库 >DB2中REVERSE函数的实现方法
DB2中REVERSE函数的实现方法
摘要:ORACLE:SQL>selectreverse('1234')fromdual;REVERSE(--------4321SQL>selec...

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:

DB2中REVERSE函数的实现方法1

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中REVERSE函数的实现方法】相关文章:

DB2编程序技巧 (七)

如何访问大型机、小型机上的DB2 9数据服务器

DB2编程序技巧 (六)

DB2专家王云谈商业智能BI

CentOS下DB2数据库安装过程详解

如何安装SQL Server 2008 Management Studio Express

DB2编程序技巧(1)

DB2死锁的解决过程全记录

IBM DB2 日常维护汇总(七)

常见数据库系统比较 DB2数据库

精品推荐
分类导航