DB2中实现Oracle的相关功能

发表于:2007-9-20 11:26

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:未知    来源:网络转载

#
DB2
#
Oracle

        在现实的应用中,大家可能经常会遇到在DB2中如何实现Oracle的某些功能,在此我简单地总结一下,实现某一功能可能会有很多种方法,在此没有全部列出,欢迎大家继续探讨,共同近步﹗(以下主要以Oracle 8i和DB2 7.X为例)。

1、如何取一表前n笔记录的Oracle和DB2的写法

        Oracle可以这样实现:

Select * from user.bsempms where rownum<=n;


        DB2可以这样实现:

Select * from db2admin.bsempms fetch first n rows only;


        另外也可以用row_number() over()去实现的;

2、如何取得当前日期的Oracle和DB2的写法

        Oracle可以这样实现:

Select sysdate from dual; 


        DB2可以这样实现:

Select current timestamp from sysibm.sysdummy1;


3、如何连接字段的Oracle和DB2的写法

        Oracle可以这样实现:

Select emp_no||emp_nam from bsempms;

Select concat(emp_no,emp_nam) from bsempms;


        DB2可以这样实现:

Select emp_no||emp_nam from db2admin.bsempms;

select emp_no concat emp_nam from db2admin.bsempms;


4、如何查询表的结构的Oracle和DB2的写法

        Oracle可以这样实现:

Select sysdate from dual;


        DB2可以这样实现:

Select current timestamp from sysibm.sysdummy1;


5、内连接INNER JOIN的Oracle和DB2的写法

        Oracle可以这样实现:

Select a.* from bsempms a,bsdptms b where a.dpt_no=b.dpt_no;


        DB2 可以这样实现:

Select * from db2admin.bsempms inner join db2admin.bsdptms  

on db2admin.bsempms.dpt_no=db2admin.bsdptms.dpt_no;


6、外连接的Oracle和DB2的写法(右外连接,左外连接,完全外连接,组合外连接)

        Oracle可以这样实现:

Select a.* from bsempms a,bsdptms b where a.dpt_no=b.dpt_no(+);

Select a.* from bsempms a,bsdptms b wherea.dpt_no(+)=b.dpt_no;


        DB2可以这样实现:

Select * from db2admin.bsempms right outer join db2admin.bsdptms

on db2admin.bsempms.dpt_no=db2admin.bsdptms.dpt_no;

Select * from db2admin.bsempms left outer join db2admin.bsdptms

on db2admin.bsempms.dpt_no=db2admin.bsdptms.dpt_no;

Select * from db2admin.bsempms full outer join db2admin.bsdptms

on db2admin.bsempms.dpt_no=db2admin.bsdptms.dpt_no;


7、如何执行脚本SQL文件的Oracle和DB2的写法

        Oracle可以这样实现:

SQL>@$PATH/filename.sql;


        DB2可以这样实现:

db2 -tvf $PATH/filename.sql


        文件中每行以 ; 结尾。

《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号