会员控制台 会员登陆 会员注册 最后更新 高级搜索 会员投稿 退出登陆
设为首页
收藏本站
留言给我
  首页 | 操作系统类 | 程序设计类 | 数据库类 | 应用服务类 | 网络及硬件类 | 其他技术 | GBunix论坛
操作系统类
程序设计类
数据库类
应用服务类
网络及硬件类
其他技术
Unix中文 / 数据库类 / DB2 / Oracle 和DB2 的一些异同点
Oracle 和DB2 的一些异同点
2004-08-13          点击:
Oracle 和DB2 的一些异同点

1.Table space for indexes 的不同

Oralce:

Create TABLE T1 .............IN DATA_TA
Create Index ........ ON T1  ...... IN INDX_TS


DB2:

Create TABLE T1 ........ IN DATA_TS INDEX IN INDX_TS
Create INDEX  .....ON T1

2.RowID

Oracle:

Oracle 有RowID ,它是由数据库唯一产生的,在程序里可以获得

DB2:

DB2的相对应的这个值不能被程序获得

3.一些转换

Oracle:

Oracle 支持一些转换,比如:
Create table t1(c1 int);
Select * from t1 where c1='1'
Select  'abc'||2  from t1


DB2:

DB2不支持一些转换,比如:
Create table t1(c1 int);
Select * from t1 where c1=CAST('1' AS INT)
Select  'abc'||CHAR(2)  from t1


4.函数的值做为表中的缺省值

Oracle:

Oracle 支持把函数的值做为表中的缺省值,比如:
Create table t1(C1 Number DEFAULT FN() NOT NULL,
               C2 DATE DEFAULT NOT NULL SYSDATE
               )


DB2:

DB2不支持把函数的值做为表中的缺省值,比如:
Create table t1(C1 INT NOT NULL,
               C2 TIMESTAMP DEFAULT CURRENT TIMESTAMP
               )
这个是不允许的


5.一些内建的函数



6.公用的同义词(Public Synonyms)

Oracle:

Oracle 支持公用的同义词            

DB2:

DB2不支持公用的同义词

7.Date/Time



8.外连接



现在,Oracle 9i也支持这种ANSI join 语法

9.字符串和null的合并

Select 'abc'||c1 from T1
C1 is null
Result :
Oracle : abc
DB2: null

要想得到'abc',DB2中需要这样处理
Select  'abc'||coalesce(c1,'') from T1

了解更多详情,参与讨论,请进入GBUNIX论坛

http://www.gbunix.com/bbs/index.php
责任编辑: trotter
发表评论 查看评论 加入收藏 Email给朋友 打印本文
给该文章评分
1 2 3 4 5 6 7 8 9 10
平均得分 0, 共 0 人评分
1 2 3 4 5 6 7 8 9 10
发表评论
标题:
内容:
声明:本站资讯均来自互联网,所有文章版权归原作者和出版者所有,如涉及版权问题,请来信告知!
Copyright © 2002-2004 GBunix.com. All rights reserved.