Oracle与SQL Server数据库的异同

本文详细比较了Oracle和SQL Server在实例、数据库、存储结构、表类型、视图、索引、JOIN算法、序列、分区、执行计划、日志和集群等方面的区别,帮助读者理解两者的核心异同。
摘要由CSDN通过智能技术生成

实例和数据库的关系

实例是运行在内存中的一系列进程,用于相应客户端请求,在内存中缓存数据以及与数据库交互等等。而数据库是实际存储数据的组织。

Oracle中一个实例只能对应一个数据库,或多个实例对应一个数据库,这种架构称为RAC--Real Application Cluster。对于每个实例,有一个SID(System ID)来唯一标识,在连接到数据库服务器时需要提供(或者提供service name也可以)。关于SID和Service name的区别可自行搜索。

SQL Server中一个实例可以对应多个数据库,同时一台机器可以按照多个实例。由于同一台机器上的多个实例需要互相区分,因此如果仅安装一个实例则使用默认实例,如果安装多个实例,则需要使用命名实例。


数据存储结构

Oracle中,关于存储的逻辑概念有:

block--由多个IO blocks组成,一般为4或8KB

extent--一段连续的blocks,用于存储特定的信息

segment--由一系列的extents构成,用于存储特定的数据库对象,例如表。每个数据库对象都存储在单独的segment中。需要注意的是segment可以跨多个data file。

tablespace -- 一个数据库有两个tablespace: System tablespace & Data tablespace。每个tablespace可有多个data file,但data file不可跨tablespace,也不可跨磁盘。


关于存储的物理结构有:

IOS block--指磁盘层面的最小读写单元

data file--数据文件,在ios层面可实际观察到的文件

具体请参考:

http://docs.oracle.com/cd/E11882_01/server.112/e40540/logical.htm#CNCPT301


SQL Server中存储的逻辑概念有:

data page--SQL Server存储数据的最小单元,大小为8KB。

extent--8个data pages构成一个extent,因此一个extent的大小为64KB。extent又分为两种,uniform and mixed。通常一个数据库对象由多个uniform extent构成,但当对象足够小的时候,也可以由多个对象共用多个mixed extents。</

一般的公司通常会在他们的信息系统架构中引入多种数据库平台,同时引入三到四种不同的RDBMS览决方案的中大型公司 也并丌少见,当然返些公司里面的DBA们通常也需要 同时拥有管理多种丌同平台的技能了。 叧在一种平台上展开工作的数据库与家们也通常会期待着在他们的下一仹工作中能学到点不一样的东西,那些有勇气的人们则愿意花时间、金钱和精力去学习 新的东西,也有其他因为换了新公司戒者是为了找新的工作而去学习新的系统的人们,毋庸置疑的一点就是公司老板和人力与家们会更加青睐亍那些拥有多个领域经 验的求职者。 依我个人的经验来看,在学习一个新的数据平台的时候,最好的方法就是在新的环境中去収现那些你已知的东西,返样学习起来会简单徆多。当然,当中也会 遇到一些全新的概念需要去学习,戒者是忘掉一些你现在已知的概念,但不管怎举说你丌是从零开始的。比如说一个做SQL Server开収人员在要写Oracle存储过程的时候可能会先去找那些内置的函数然后比较它们之间不同点,她也可能会去比较发量声明以及错误处理的异同。 本系列文章中我将尝试对Microsoft SQL ServerOracle RDBMS(以10g及以后的版本为主)进行一个深入的比较。我会主要集中亍返两种数据库乀间架构上的比较,当然不要期望我会给你一个详尽的比较清单,但是我会尽我所能的让你看清返两种当今世上应用最广的数据库之间的相同和相异乀处。本文是以一个SQL Server DBA的觇度去构思和写作的,不过相信返对Oracle与家门了览SQL Server返一面也是徆有参考价值的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值