分享

DB2中实现Oracle的相关功能

 WindySky 2007-11-14

在现实的应用中,大家可能经常会遇到在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;zzMitug
Select concat(emp_no,emp_nam) from bsempms;

DB2可以这样实现:

Select emp_no||emp_nam from db2admin.bsempms;zzMitug
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(+);zzMitug
Select a.* from bsempms a,bsdptms b wherea.dpt_no(+)=b.dpt_no;

DB2可以这样实现:

Select * from db2admin.bsempms right outer join db2admin.bsdptmszzMitug
on db2admin.bsempms.dpt_no=db2admin.bsdptms.dpt_no;zzMitug
Select * from db2admin.bsempms left outer join db2admin.bsdptmszzMitug
on db2admin.bsempms.dpt_no=db2admin.bsdptms.dpt_no;zzMitug
Select * from db2admin.bsempms full outer join db2admin.bsdptmszzMitug
on db2admin.bsempms.dpt_no=db2admin.bsdptms.dpt_no;

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

Oracle可以这样实现:

SQL>@$PATH/filename.sql;

DB2可以这样实现:

db2 -tvf $PATH/filename.sql

文件中每行以 ; 结尾。

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多