Oracle一些逻辑性问题。 最近很迷茫想问是的Oracle和SQLServer的区别,实质性的区别。希望大家能踊跃发言,回答的越详细,分越高,不够再加100分。谢谢大家了。同时祝大家新的一年心想事成!万事如意!! 解决方案 » 免费领取超大流量手机卡,每月29元包185G流量+100分钟通话, 中国电信官方发货 oracle运行稳定,价格高,维护更需要技术sql sever 运行相对不够稳定,价格低廉,维护也比较简单做一些不太大的系统sql sever 就够用了,不过如果系统比较庞大,或数据比较庞大,建议用oracle 实质性的区别不知道。介于sqlserver只能部署到windows上,仅此一点,就不用他 orcale 一般用于大型数据库 sql server 用于普通的数据库oracle安全性好,价格高,操作也更复杂 当数据库是SQL Server的时候Enterprise Library访问起来非常方面,完全可以用Enterprise Library Configuration工具配置后就可以在代码中访问DB,但是当数据换成Oracle的时候就没有那么方便了,毕竟是两个公司的东西多少有些不同之处,下面就我知道的Oracle(以9i为例)与SQL Server的不同点总结一下:1、数据类型的不同; SQL Server2000 Transact-SQL 的基本数据类型有:bigint binary bit char cursor datetime decimal float image int money nchar ntext nvarchar real smalldatetime smallint smallmoney text timestamp tinyint varbinary varchar uniqueidentifier SQL Server大家都比较熟悉,各个类型的含义就在此不一一列出。 Oracle 9i基本数据类型有:名称 含义 Char 用于描述定长的字符型数据,长度<=2000字节 varchar2 用于描述变长的字符型数据,长度<=4000字节 nchar 用来存储Unicode字符集的定长字符型数据,长度<=1000字节 nvarchar2 用来存储Unicode字符集的变长字符型数据,长度<=1000字节 number 用来存储整型或者浮点型数值 Date 用来存储日期数据 Long 用来存储最大长度为2GB的变长字符数据 Raw 用来存储非结构化数据的变长字符数据,长度<=2000字节 Long raw 用来存储非结构化数据的变长字符数据,长度<=2GB rowid 用来存储表中列的物理地址的二进制数据,占用固定的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 块,可能在该块内部进行修改,然后返回到调用应用程序。 补充一下.http://www.xker.com/edu/database/121/06112310105616049.html原文 .你可以看看。不是我写网上找地.还不错. 求教一条LIKE SQL语句的优化 UpdateXML函数的弊端,如何解决 简单问题~~~列相加 50分~~~马上结贴 一个SQL错误,谁能帮我看看,急啊~~ Materialized View 中cross inner问题(急) 调用存储过程 提示无效状态 请大虾们帮忙看看谢谢 OCI怎么比OO4O还慢?(VC) 动态sql一问 sql server 转到oracle 的疑问 如何在linux下自动启动Oracle9i???急急急急急!!在线给分!!!! 关于oracle 10g 透明网关乱码的问题 求apex中文使用说明书
sql sever 运行相对不够稳定,价格低廉,维护也比较简单做一些不太大的系统sql sever 就够用了,不过如果系统比较庞大,或数据比较庞大,建议用oracle
介于sqlserver只能部署到windows上,仅此一点,就不用他
oracle安全性好,价格高,操作也更复杂
1、数据类型的不同;
SQL Server2000 Transact-SQL 的基本数据类型有:
bigint binary bit char cursor
datetime decimal float image int
money nchar ntext nvarchar real
smalldatetime smallint smallmoney text timestamp
tinyint varbinary varchar uniqueidentifier
SQL Server大家都比较熟悉,各个类型的含义就在此不一一列出。 Oracle 9i基本数据类型有:名称 含义
Char 用于描述定长的字符型数据,长度<=2000字节
varchar2 用于描述变长的字符型数据,长度<=4000字节
nchar 用来存储Unicode字符集的定长字符型数据,长度<=1000字节
nvarchar2 用来存储Unicode字符集的变长字符型数据,长度<=1000字节
number 用来存储整型或者浮点型数值
Date 用来存储日期数据
Long 用来存储最大长度为2GB的变长字符数据
Raw 用来存储非结构化数据的变长字符数据,长度<=2000字节
Long raw 用来存储非结构化数据的变长字符数据,长度<=2GB
rowid 用来存储表中列的物理地址的二进制数据,占用固定的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 块,可能在该块内部进行修改,然后返回到调用应用程序。