深度对比Oracle与SQL Server 联系客服

发布时间 : 星期日 文章深度对比Oracle与SQL Server更新完毕开始阅读

在SQL中如果一个事务从开始执行到结束时了错了,它就会回滚到开始之前。在ORACLE中它采用的是定点回滚,就是该事务函数化和精确错误定位,用savepoint标记保存点,用Rollback标记回滚错误的保存点。

在SQL中循环只有WHILE一种这用起来不灵活,在ORACLE中有多种循环(LOOP循环、WHILE循环、FOR循环)。

在SQL中游标的使用比较复杂,不能同时打开一个以上的游标,因为它只有一个全局变量

@@Fast_statues,而且声明游标也麻烦,关闭游标时也不清除内存的。ORACLE中游标是以提高速度全部统一的单项游标,可以允许多用户异步读取,而且声明比较简单,就一句declare cursor游标名 is select 语句就可以了。

容错机制:SQL中的错误机制比较复杂,没有提供错误描述;ORACLE中容错类型有三种,一个是预定义错误,一个是非预定义错误,一个是用户自定义,其中在自定义错误中它有两个是在SQL中不有的,那就是SQLCODE 错误号、SQLERRM错误描述。

文件体系结构:SQL中有.MDF(主要数据文件)、.NDF(扩展文件,可以有多个)、.LDF(日志文件,可以有多个,存放在联机重做日志数据,这里的日志文件有一个缺点就是如果日志文件已填小巧玲珑的话,SQL将自动停止运行并等待人工干预,所以要经常监控日志的情况保证系统的稳定运行)。ORACLE中有.DBF(主要数据文件)、.RDO(日志文件,用来做灾难性的数据备份)、.CTL(控制文件,将数据库的物理文件映射到了数据字典中的逻辑表空间和连机重做日志文件上去,确保数据的一致性)、.ORA(参数文件)。

SQL只能是本机备份本机的数据库,无法联机备份,而且备份压缩很低,占用了大量空间。ORACLE提供了7种备份机制,具有联机备份功能,有专门的备份机子。

Oracle的日志默认有3个,先写入1号日志,满了后再写入2号日志,2号满了再写入3号日志,3号满了后Oracle将自动备份1号日志的内容,然后清空后写入新的日志信息,且Oracle的日志有多路复用功能,我们可以为日志创建多个镜像,把相同的日志信息同时写入多个日志文件中,这样可以防止磁盘损坏造成的数据丢失。

SQL Server对每个数据库只能分配一个日志文件。且当日志填满后,日志将停止工作,等待人工干预,而无法自动重用。Oracle的控制文件记录了数据库文件的物理位置和有效性,在每次打开Oracle系统都将自动对数据进行验证,查看其有效性,防止数据的丢失,这体现了Oracle对数据管理的严密性。

SQL Server无此安全机制,只用在使用到了数据库的信息后,系统才去查找数据是否存在。Oracle的参数文件init.ora是可调的,既我们可以根据数据库的规模调整Oracle对系统资源的使用情况,以达到最合理的资源分配,让Oracle达到最佳的性能。

SQL Server的配置参数是内定的不可调整,它对系统资源的分配是固定的,不受拥护控制,因此无法同时处理大量用户的需求,这限制了它只能作为中,小型数据库。Oracle以块为最小存储单位,以区为单位

分配空间,用户可以根据需要自己定义块的大小,且区可以按等额或递增进行分配,这可以大大减少系统的I/O操作提高数据库的性能。

SQL Server中以页为单位或使用扩展类型以8页为一单位进行空间分配而无法人工干预,当遇到频繁存储或大数据量存储时,系统将频繁进行I/O操作使工作效率低下。

Oracle中的SQL语句书写规范且提供了完整的函数和数据类型。Oracle提供了健全的错误机制,用户可以轻松的获得错误位置和错误原因而加以修改。用户还可以自己定义所须的错误类型,用以检查逻辑错误。Oracle中对数据类型的转换和游标的定义也十分方便。因此,我们对代码的书写和维护也比SQL Server方便许多。

SQL Server使用类C语言,不易维护和查看代码。SQL Server包含的数据类型太少,无法定义结构体,数组,对象。SQL Server无法定义流程机制,类型转换也极不方便,SQL Server中对游标定义十分复杂,且当用户定义的多个游标同时打开时系统却只有一个游标变量,这是SQL SERVER中一个严重的缺陷。

ORACLE中用户可以根据数据需要在创建块时定义填充因子(空闲空间的百分比)和复用因子(当块的存储数据所占的空间下降到这个百分比之下时,块才重新标记为可用)。用户可以根据记录变化频率和数据量的大小设置合适的填充因子和空闲因子。

SQL SERVER只有填充因子,而它的定义与ORACLE刚好相反,它定义的是剩余可用空间的百分比。而SQL SERVER中没有复用因子,当页中数据低于填充因子,但剩余的空间已经不可能再插入新的数据,但页还是标记为可用的,当系统要写入新数据都要访问这个页而浪费时间,这种页称为废页,将使系统插入新数据时浪费大量时间查找可用的页。

ORACLE在创建表时用户可以精确定义数据存放的表空间,甚至可以把一张表分开存放在多个表空间中,这样可以将数据量庞大的表按某些字段分开存放,这将给查询带来极高的效率。

3. ORACLE的表空间管理和SQL SERVER的文件组对比 3.1. 概念对比

SQL Server里对数据库文件的管理比较简单,主要的概念有:

1. 文件组:数据库对象的存储分配单位,目的是为了容纳更多的数据库文件、扩展空间 2. 文件:文件组的成员,有空间分配是否自动增长的管理 3. 默认文件组

4. 只读文件组:这是在sqlserver2005后才有的概念,sqlserver2000没有! 5. master、tempdb数据库:用于基本的字典、临时空间管理 Oracle里对数据库文件的管理就比较复杂了,基本的概念: 1. 表空间

2. 表空间的数据文件成员 3. 默认表空间 4. 只读表空间 5. 脱机表空间

6. 脱机表空间数据文件成员

7. system、sysaux、undo、temporary表空间专门作为数据自动、undo、临时空间存在 8. bigfile文件

9. 对空间进行[logging|nologging|force logging] 从上的基本对比中:

1. Oracle的空间管理有sqlserver所没有的许多特性;

2. Oracle的管理变得复杂了。其实某些特性完全可以依赖于os,也许这就是Oracle为了平台无关所做的妥协吧。

3.2. Oracle表空间的基本要素

1. 性质:用户的永久表空间、undo表空间、temporary表空间 2. 是否使用bigfile特性 3. 名称

4. 表空间文件成员,如果使用bigfile特性,只能使用一个文件成员:datafile、tempfile 5. 是否记录日志:logging、nologging、force logging。不能用户temporary、undo表空间上 6. 是否联机:noline、offline

7. 数据块尺寸:blocksize {2k、4k......} 。必须要相应配置db_nk_cache_size初始化参数。且值不能小于os的块大小!temporary表空间不能使用非标准的数据块!

8. 扩展区管理模式,注意temporary、undo表空间各有特殊要求!

extent management {dictionary|local[autoallocate|uniform [size n[m|k|g..]]]}

9. 段管理模式,不能用户temporary、undo表空间上:

segment space management {auto|manual}

10. 闪回特性是否打开:flashback {on|off} 。不能用户temporary、undo表空间上 11. 闪回保留模式:retention {guarantee|noguarantee}

3.3. Oracle的和表空间相关的基本操作

0. 注意:

1) temporary表空间只能使用add tempfile file-spec一个语句 2) undo表空见可以修改的地方也十分有限 3) system表空间不允offline 和 read ……

1. 增加表空间:

create [bigfile] tablespace tbs_name datafile file-spec,..

2. 修改表空间:增加、删除文件:

alter tablespace tbs_name {add|drop} {datafile|tempfile} file-spec,..

3. 修改表空间:移动、重命名文件:

alter tablespace tbs_name rename datafilefile-spec,.. tofile-spec,..

4. 修改表空间:联机、脱机文件:

alter tablespace tbs_name {datafile|tempfile}{online|offline}

5. 修改表空间:表空间名称:

alter tablespace tbs_name rename to new_tabs_name

6. 修改表空间:日志模式:

alter tablespace tbs_name {logging|nologging|[no] force logging}

7. 修改表空间:表空间联机、脱机模式:

alter tablespace tbs_name {online|offline}

8. 修改表空间:修改读、写模式:

alter tablespace tbs_name read {only|write}

9. 修改表空间:修改闪回模式:

alter tablespace tbs_name flashback {on|off}

10. 修改表空间:修改闪回数据保留模式:

alter tablespace tbs_name retention {guarantee|noguarantee}

11. 修改表空间:修改bigfile文件的尺寸: