tempad
ReadyGo!技术成就梦想 >>数据库文摘 >> SQL Server 与Oracle的不同点(从微观上)

SQL Server 与Oracle的不同点(从微观上)

ReadyGo!技术成就梦想 网络搜索 efish 2008-2-24 2:52:44

     当数据库是SQL Server的时候Enterprise Library访问起来非常方面,完全可以用Enterprise Library Configuration工具配置后就可以在代码中访问DB,但是当数据换成Oracle的时候就没有那么方便了,毕竟是两个公司的东西多少有些不同之处,下面就我知道的Oracle(以9i为例)与SQL Server的不同点总结一下:
1、数据类型的不同;
      SQL Server2000 Transact-SQL 的基本数据类型有:

bigintbinarybitcharcursordatetimedecimalfloatimageintmoneyncharntextnvarcharrealsmalldatetimesmallintsmallmoneytexttimestamptinyintvarbinaryvarcharuniqueidentifier 

  SQL Server大家都比较熟悉,各个类型的含义就在此不一一列出。

      Oracle 9i基本数据类型有:

名称含义Char用于描述定长的字符型数据,长度<=2000字节varchar2用于描述变长的字符型数据,长度<=4000字节nchar用来存储Unicode字符集的定长字符型数据,长度<=1000字节nvarchar2用来存储Unicode字符集的变长字符型数据,长度<=1000字节number用来存储整型或者浮点型数值Date用来存储日期数据Long用来存储最大长度为2GB的变长字符数据Raw用来存储非结构化数据的变长字符数据,长度<=2000字节Long raw用来存储非结构化数据的变长字符数据,长度<=2GBrowid用来存储表中列的物理地址的二进制数据,占用固定的10个字节Blob用来存储多达4GB的非结构化的二进制数据Clob用来存储多达4GB的字符数据nclob用来存储多达4GB的Unicode字符数据Bfile用来把非结构化的二进制数据存储在数据库以外的操作系统文件中urowid用来存储表示任何类型列地址的二进制数据float用来存储浮点数

2、自增行字段的区别
      在SQL Server 中为自增列(IDENTITY );
      在Oracle中为Oracle 序列是原子对象,并且是一致的。也就是说,一旦您访问一个序列  号,Oracle 将在处理下一个请求之前自动递增下一个编号,从而确保不会出现重复值。
3、Stored Procedure的区别
      在大多数Oracle中的书籍中都称为“过程”,在SQL Server中叫存储过程。Oracle 过程与 Microsoft SQL Server 存储过程之间的主要区别是:Oracle 过程必须将值作为输出参数返回,并且必须使用输出参数将结果集作为 REF CURSOR 对象返回给调用程序。
4、PL/SQL 和 T-SQL 中的存储过程之间的一个重大差异是 PL/SQL 所使用的 Oracle 包 结构。在 T-SQL 中没有等效元素。包是在逻辑上相关的编程块(如存储过程和函数)的容器。它包含两个部分:

●规范:定义包的名称,并为包中的每个存储过程或函数提供方法签名(原型)。规范头还定义所有全局声明。规范的样式类似于 C 或 C++ 头文件。
 
● 正文:包含包头中定义的存储过程和函数的代码。
 

每个存储过程或函数的参数都出现在括号内,并且用逗号分隔。每个参数还根据需要用以下三个标识符中的一个进行标记:

● IN:该值从调用应用程序传递到 PL/SQL 块。如果未指定标识符,则 IN 为默认传递方向。
 
● OUT:该值由存储过程生成,并传递回调用应用程序。
 
● INOUT:该值被传递到 PL/SQL 块,可能在该块内部进行修改,然后返回到调用应用程序。
 

每个参数也都被标记以指示数据类型。

责任编辑: efish 参与评论 查找更多:
相关文章
万里开源携手MySQL数据库 共建中国研发中心 万里开源携手MySQL数据库 共建中国研发中心
数据库市场:甲骨文IBM和微软名列前三 数据库市场:甲骨文IBM和微软名列前三
Oracle数据库比SQL Server更存在缺陷 Oracle数据库比SQL Server更存在缺陷
SQL Server2005发布元年 微软正身企业级应用 SQL Server2005发布元年 微软正身企业级应用
微软SQL Server 2005成功领跑企业市场 微软SQL Server 2005成功领跑企业市场
MySQL沿用旧版GPL 两手准备仍参与第3版起草 MySQL沿用旧版GPL 两手准备仍参与第3版起草
SQL2005较之SQL2000的改进 SQL2005较之SQL2000的改进
常见数据库系统之比较 - 数据库的发展和现状 常见数据库系统之比较 - 数据库的发展和现状
常见数据库系统之比较 - Oracle数据库 常见数据库系统之比较 - Oracle数据库
微软推预览版SQL Server 2005 微软推预览版SQL Server 2005
2秒记住本站域名

玩过泡泡龙吗?Readygo?Go! 再加上.Com.Cn的后缀,那就是大名小顶的ReadyGo.com.cn

分类导航
ReadyGo!技术成就梦想