zoukankan      html  css  js  c++  java
  • 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 块,可能在该块内部进行修改,然后返回到调用应用程序。
     

    每个参数也都被标记以指示数据类型。
    5、关于Guid
          SQL Server有专门的uniqueidentifier 数据类型来存储Guid类型的字符,Oracle没有改数据类型;SQL中产生Guid使用函数NEWIDOracle中使用SYS_GUID(Oracle8i及其以后版本才引入);使用的示例分别为:
    SQL Server:

    SELECT NEWID()


    Oracle:

    SELECT SYS_GUID () FROM DUAL;

    可以分别在SQL的查询分析器和TOAD中执行看看结果,SQL Server产生的是类似“C6D4ABBF-9AD6-4255-AADE-C0EDBF1E27B7”,而Oracle的为“5A9C4407068749C7B0662D351C099356”,两者还是有些区别。

    6、在T-SQL中常规标识符和分隔标识符包含的字符数必须在 1 到 128 之间,对于本地临时表,标识符最多可以有 116 个字符,与系统保留字冲突的标识符用[]括起来;在PL-SQL中标识符最大长度不能超过30个字符,与系统保留字冲突的字段的标识符用""包括起来。

    漂泊雪狼

  • 相关阅读:
    【Linux】gvim封装至gvi命令
    unity, GUI.Button texture is black
    建了个百度贴吧:图形底层吧
    unity, imageEffect在android上不显示的问题
    3dmax fx shader, vertex color
    unity, editorWindow lose data when enter play mode
    unity, undo
    unity, editorWindow update计时
    unity, imageEffect的最后一步blit所用的shader,应该关闭zwrite和ztest
    unity, GUIStyle and Skin
  • 原文地址:https://www.cnblogs.com/weiweictgu/p/568968.html
Copyright © 2011-2022 走看看