SQLServer和Oracle的区别

来源:互联网 发布:bilibili视频制作软件 编辑:程序博客网 时间:2024/04/27 23:27

转载于:http://www.2cto.com/database/201207/144792.html

操作系统

oracle支持多种操作系统,sql server只支持windows

难度

oracle给dba更多的灵活性,可以根据实际情况调整参数,使你的应用的性能最佳,因而带来一个缺点是很难上手;sql server则相反,当然很容易上手。

体系结构

oracle的文件体系结构

  • 数据文件 .dbf(真实数据)
  • 日志文件 .rdo
  • 控制文件 .ctl
  • 参数文件 .ora

sql server的文件体系结构

  • .mdf (数据字典)
  • .ndf (数据文件)
  • .ldf (日志文件)

oracle存储结构

在oracle里有两个块参数pctfree(填充因子)和pctused(复用因子),可控制块确定块本身何时有,何时没有足够的空间接受新信息(对块的存储情况的分析机制)
这样可降低数据行连接与行迁移的可能性。块的大小可设置(oltp块和dss块)
在oracle中,将连续的块组成区,可动态分配区(区的分配可以是等额的也可以是自增长的)可减少空间。

分配次数

在oraclel里表可以分为多个段,段由多个区组成,每个段可指定分配在哪个表空间里(段的类型分为:数据段、索引段、回滚段、临时段、cash段。oracle里还可对表进行分区,可按照用户定义的业务规则、条件或规范,物理的分开磁盘上的数据。
这样大大降低了磁盘争用的可能性。

oracle有七个基本表空间:

  • ·system表空间(存放数据字典和数据管理自身所需的信息)
  • ·rbs回滚表空间
  • ·temp临时表空间
  • ·tools交互式表空间
  • ·users用户默认表空间
  • ·indx索引表空间
  • ·dbsys福数据表空间

不同的数据分别放在不同的表空间(数据字典与真实数据分开存放),在oracle里基表(存储系统参数信息)是加密存储,任何人都无法访问。只能通过用户可视视图查看。

sql server 存储结构
以页为最小分配单位,每个页为8k(不可控制,缺乏对页的存储情况的分析机制),可将8个连续的页的组成一个‘扩展’,以进一步减少分配时所耗用的资源。(分配缺乏灵活性),在sql server里数据以表的方式存放,而表是存放在数据库里。

sql server有五个基本数据库:

  • ·master(数据字典)
  • ·mode(存放样版)
  • ·tempdb(临时数据库)
  • ·msdb(存放调度信息和日志信息)
  • ·pubs(示例数据库)

真实数据与数据字典存放在一起。对系统参数信息无安全机制。

登入管理

oracle登入管理

  • ·system/manager (初始帐户)
  • ·sys/change_on_nstall
  • ·install/oracle(安装帐户)
  • ·scott/tiger(示例数据库,测试用)

在oracle里默认只有三个系统用户,oracle是通过用户登入。

sql server登入管理

  • ·sql server身份验证

- ·windows 身份验证

在sql server里是通过windows用户帐户或是用sql server身份验证连接数据库的。

索引

sql server的索引分为聚集索引和非聚集索引,还包括全文索引;

oracle的索引包括:b+树索引,bitmap位图索引,函数索引,反序索引,主键索引,散列索引,本地索引。

容错机制

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

开放性3

SQL Server 只能在windows 上运行,没有丝毫的开放性,操作系统的系统的稳定对数据库是十分重要的。Windows9X系列产品是偏重于桌面应用,NT server只适合中小型企业。而且windows平台的可靠性,安全性和伸缩性是非常有限的。它不象unix那样久经考验,尤其是在处理大数据量的关键业务时。
Oracle 能在所有主流平台上运行(包括 windows)。完全支持所有的工业标准。采用完全开放策略。可以使客户选择最适合的解决方案。对开发商全力支持。

可伸缩性,并行性

SQL server DB2 并行实施和共存模型并不成熟。很难处理日益增多的用户数和数据卷。伸缩性有限。
Oracle 平行服务器通过使一组结点共享同一簇中的工作来扩展windownt的能力,提供高可用性和高伸缩性的簇的解决方案。 如果windowsNT不能满足需要, 用户可以把数据库移到UNIX中。

安全性

SQL server 没有获得任何安全证书。

Oracle Server 获得最高认证级别的ISO标准认证。

性能

SQL Server 多用户时性能不佳

Oracle 性能最高, 保持windowsNT下的TPC-D和TPC-C的世界记录。

客户端支持及应用模式

SQL Server C/S结构,只支持windows客户,可以用ADO,DAO,OLEDB ,ODBC连接.

Oracle 多层次网络计算,支持多种工业标准,可以用ODBC, JDBC,OCI等网络客户连接

操作简便

SQL Server 操作简单,但只有图形界面.

Oracle 较复杂, 同时提供GUI和命令行,在windowsNT和unix下操作相同

使用风险

SQL server 完全重写的代码,经历了长期的测试,不断延迟,许多功能需要时间来证明。并不十分兼容早期产品。使用需要冒一定风险。

Oracle 长时间的开发经验,完全向下兼容。得到广泛的应用。完全没有风险。

0 0