sqlserver和oracle主要有什么区别

发布网友

我来回答

2个回答

懂视网

   1.数据类型不同。
      sql server 的数据类型

int ,smallint ,char,varchar,nchar,nvarchar,ntext,datetime,smalldatetime,money,decima, float,bit 

      oracle 的数据类型:number(p,s),char,varchar2,Date,LOB
               注意:insert into table_name values(‘1‘,‘张三‘,‘男‘,date‘2012-3-5‘);插入字符串日期前加date转换类型
      
   2.获得当前系统时间的函数不同。
      sql server :getdate()
      
      oracle:sysdate
            例如:设定日期格式的函数:to_char(sysdate,‘yyy-mm-dd‘);
   3.在oracle中没有默认约束的说法
      sql server 中添加默认约束:alter table talbe_name add DF_table_name default(‘男‘) for sex;
      
      oracle 中添加默认值:alter table table_name modify(sex default(‘男‘));

  4.连接变量和字符串的方式不一样
      sql server 中连接:使用“+”连接,例如:print ‘aaaa‘+@name;
      
      oracle  中连接:使用“||”连接,例如:dbms_output.put_line(‘aaa‘||name);---name为变量
 
  5.oracle没有identity自动增长列,而是使用序列实现增长
      sql server 自动增长:在表的主键列中可直接使用identity(1,1)实现增长
      
      oracle 使用序列自动增长:
                                 create sequence se_id 
                                 start with 1
                                 increment by 1
      使用序列实现自动增长:se_id.nextval
  6.条件语句if……else……的语法不同
      sql server中:
            if 条件
            begin
              …………
            end
            else
            begin
              …………
            end 
      oracle中:
            if 条件1 then
               …………;
            elsif 条件2 then
               …………;
            else
              …………;
            end if;
            
  7.case语句的语法不同
      sql server中:
            select ....case.....(else)....end....语句
            select stuno ‘学号‘,case
            when grade>=90 and grade<=100 then ‘‘
            when grade>=80 and grade<90 then ‘‘
         when grade>=70 and grade<80 then ‘‘
         when grade>=60 and grade<70  then ‘‘
            else ‘差‘
            end as ‘等级‘ from score
            go
      oracle中:
            declare
               nums number:=&nos;&nos表示提示传入值
            begin
              case nums
                when 100 then
                  dbms_output.put_line(‘满分也,不错‘);
                when 90 then
                  dbms_output.put_line(‘90分页很不错了‘);
                end case;
            end;
  8.触发器创建语法不同
     sql server中:
        首先判断触发器是否已经存在
         if exists (select * from sys.sysobjects where name=‘tr_delete‘)
     如果存在先删除
    drop trigger tr_delete
         go
         
        创建触发器
        create trigger tr_delete
        on bookInfo
        instead of delete
        as
            定义变量
            declare @bookid int 
            select @bookid=Bookid from deleted---deleted执行删除语句( delete from BookInfo where BookId=1),自动生成的deleted表
            删除与该图书的相关记录(先删除从表再删除主表)
            delete from borrowinfo where  bookid=@bookid
            delete from backinfo where  bookid=@bookid
            delete from BookInfo where BookId=@bookid
            判断
            if @@error<>0
            begin
                print ‘删除失败‘
                rollback transaction
            end
            else
            begin
                print ‘删除成功‘
            end
        go
        delete from BookInfo where BookId=1        
         
     oracle中:
        创建触发器
        create or replace trigger tri_test
        before insert or update or delete 
        on table_name
        [for each row]---如果要使用 :new /:old 就必须使用行触发器
        declare
             nums varchar2(20);
        begin
          select ‘F‘||lpad(‘aa‘,5,0) into nums from dual;
        end;
     
  9.oracle中的存储过程
             sql server中存储过程:
            
             判断存储过程是否已经存在
            if exists(select * from sys.sysobjects where name=‘proc_name‘)
     如果存在先删除
     drop proc proc_name
            go
            
            创建存储过程语句
            create proc/procedure proc_name
            @参数名1 数据类型 [out/output],
            @参数名2 数据类型 [out/output]
            as
                  …………
            go
            
            调用存储过程
            如果有输出参数,则需定义变量(假设@参数2为输出参数)
            declare @变量名 数据类型
            exec proc_name @参数名1=‘aaa‘,@参数名2=@变量名 out
            
            
            oracle中带游标及循环的存储过程
            
             create or replace procedure proc_selCurrent
             (
                    names varchar2
             )
             as
                    cursor cursor_sel
                    is
                    select DepositSum,cardType,name,state from CurrentAccount where name like ‘%‘||names||‘%‘;
                    dd number;
                    cc number;
                    nn varchar2(20);
                    sta number;
                    begin
                      open cursor_sel;
                           loop
                             fetch cursor_sel into dd,cc,nn,sta;
                             dbms_output.put_line(‘存款金额:‘||dd||‘姓名:‘||nn);
                           exit when cursor_sel%notfound;
                           end loop;
                      close cursor_sel;
                    end;
                    
              调用存储过程
              begin
                proc_selCurrent(‘a‘);
              end;
                      
 10.创建用户的方式不同
       sql server中
           1、创建登陆账号:sa-----123456
                 create Login 登陆名称 with password=‘登陆密码‘
                 
          修改登陆账户:
                 alter Login 登陆名称 with name=‘新登录名称‘ and password=‘新登录密码‘
          禁用/启用登陆账号
                 alter Login 登录名称 disable(禁用)/enable(启用)
          删除登陆账号
                 drop Login 登录名称
                 
           2、创建用户:
            create user 用户名 for/from Login 登陆名称
            
            修改用户名
            alter user 用户名 with name=‘新用户名‘
            
           删除用户名
            drop user 用户名
            
            授权限
            grant select/update/delete/insert on 表名 to 用户名
              
            
         oracle中:
        
            创建用户语法:
                  create user 用户名
                  identified by 密码
                  default tablespace users
                  temporary tablespace temp
                  quota 10M on users
                  
              修改密码:
                  alter user 用户名 identified by 新密码
                  
              授予权限:
                  grant create session to 用户名
                  
               删除用户
                  drop user 用户名 cascade;
                  
                  

版权声明:本文为博主原创文章,未经博主允许不得转载。

SQLServer与Oracle的对比

标签:

热心网友

1,oracle支持多种操作系统,sql server只支持windows。
2,oracle给dba更多的灵活性,可以根据实际情况调整参数,使你的应用的性能最佳,因而带来一个缺点是很难上手;sql server则相反,当然很容易上手。
体系结构
oracle的文件体系结构为:
数据文件 .dbf(真实数据)
日志文件 .rdo
控制文件 .ctl
参数文件 .ora
sql server的文件体系结构为:
.mdf (数据字典)
.ndf (数据文件)
.ldf (日志文件)
www.2cto.com
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有五个基本数据库: www.2cto.com
·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不是一种语言,而是对oracle数据库传输指令的一种方式。
sql中null既不是字符也不是数字,它是缺省数据。oracle提供了nvl函数来解决。
oracle中的字符串连接为 string1‖string2 ,sql中为string1+string2.
集合操作:在sql中只有union(并操作),oracle中包含minus(差操作)、interect(交操作)、union(并操作)。

索引:sql的索引分为聚集索引和非聚集索引,还包括全文索引;
oracle的索引包括:b+树索引,bitmap位图索引,函数索引,反序索引,
主键索引,散列索引,本地索引。 www.2cto.com
oracle的数据类型比较复杂,有基本数据类型,衍生型,列对象型,表对象型,结构体型;

sql中的数据比较简单,只有一些简单的基本数据类型无法提供事务操作。
在sql中如果一个事务从开始执行到结束时了错了,它就会回滚到开始之前;
在oracle中它采用的是定点回滚,就是该事务函数化和精确错误定位,用savepoint标记保存点,用rollback标记回滚错误的保存点。
在sql中循环只有while一种这用起来不灵活,在oracle中有多种循环(loop循环、while循环、for循环)。
在sql中游标的使用比较复杂,不能同时打开一个以上的游标,因为它只有一个全局变量@@fast_statues而且声明游标也麻烦,关闭游标时也不清除内存的;oracle中游标是以提高速度全部统一的单项游标,可以允许多用户异步读取,而且声明比较简单,就一句declare cursor游标名 is select 语句就可以了。
容错机制:sql中的错误机制比较复杂,没有提供错误描述;oracle中容错类型有三种,一个是预定义错误,一个是非预定义错误,一个是用户自定义,其中在自定义错误中它有两个是在sql中不有的,那就是sqlcode 错误号、sqlerrm错误描述。

文件体系结构:sql中有.mdf(主要数据文件)、.ndf(扩展文件,可以有多个)、
.ldf(日志文件,可以有多个,存放在联机重做日志数据,这里的日志文件有一个缺点就是如果日志文件已填小巧玲珑的话,sql将自动停止运行并等待人工干预,所以要经常监控日志的情况保证系统的稳定运行)。oracle中有.dbf(主要数据文件)、.rdo(日志文件,用来做灾难性的数据备份)、.ctl(控制文件,将数据库的物理文件映射到了数据字典中的逻辑表空间和连机重做日志文件上去,确保数据的一致性)、.ora(参数文件)。

sql只能是本机备份本机的数据库,无法联机备份,而且备份压缩很低,占用了大量空间;oracle提供了7种备份机制,具有联机备份功能,有志门的备份机子。
oracle的日志默认有3个,先写入1号日志,满了后再写入2号日志,2号满了再写入3号日志,3号满了后oracle将自动备分1号日志的内容,然后清空后写入新的日志信息,且oracle的日志有多路复用功能,我们可以为日志创建多个镜像,把相同的日志信息同时写入多个日志文件中,这样可以防止磁盘损坏造成的数据丢失。
sql server对每个数据库只能分配一个日志文件。且当日志填满后,日志将停止工作,等待人工干预,而无法自动重用。 www.2cto.com
oracle的控制文件记录了数据库文件的物理位置和有效性,在每次打开oracle系统都将自动对数据进行验证,查看其有效性,防止数据的丢失,这体现了oracle对数据管理的严密性。
sql server无此安全机制,只用在使用到了数据库的信息后,系统才去查找数据是否存在。
oracle的参数文件init.ora是可调的,既我们可以根据数据库的规模调整oracle对系统资源的使用情况,以达到最合理的资源分配,让oracle达到最佳的性能。

sql server的配置参数是内定的不可调整,它对系统资源的分配是固定的,不受拥护控制,因此无法同时处理大量用户的需求,这*了它只能作为中,小型数据库。
oracle以块为最小存储单位,以区为单位分配空间,用户可以根据需要自己定义块的大小,且区可以按等额或递增进行分配,这可以大大减少系统的i/o操作提高数据库的性能。
sql server中以页为单位或使用扩展类型以8页为一单位进行空间分配而无法人工干预,当遇到频繁存储或大数据量存储时,系统将频繁进行i/o操作使工作效率低下。
oracle中的sql语句书写规范且提供了完整的函数和数据类型。oracle提供了健全的错误机制,用户可以轻松的获得错误位置和错误原因而加以修改。用户还可以自己定义所须的错误类型,用以检查逻辑错误。oracle中对数据类型的转换和游标的定义也十分方便。因此,我们对代码的书写和维护也比sql server方便许多。
sql server使用类c语言,不易维护和查看代码。sql server包含的数据类型太少,无法定义结构体,数组,对象。sql server无法定义流程机制,类型转换也极不方便,sql server中对游标定义十分复杂,且当用户定义的多个游标同时打开时系统却只有一个游标变量,这是sql server中一个严重的缺陷。

oracle中用户可以根据数据需要在创建块时定义填充因子(空闲空间的百分比)和复用因子(当块的存储数据所占的空间下降到这个百分比之下时,块才重新标记为可用)。用户可以根据记录变化频率和数据量的大小设置合适的填充因子和空闲因子。

sql server只有填充因子,而它的定义与oracle刚好相反,它定义的是剩余可用空间的百分比。而sql server中没有复用因子,当页中数据低于填充因子,但剩余的空间已经不可能再插入新的数据,但页还是标记为可用的,当系统要写入新数据都要访问这个页而浪费时间,这种页称为废页,将使系统插入新数据时浪费大量时间查找可用的页。

oracle在创建表时用户可以精确定义数据存放的表空间,甚至可以把一张表分开存放在多个表空间中,这样可以将数据量庞大的表按某些字段分开存放,这将给查询带来极高的效率。
www.2cto.com
随着信息技术的飞速发展,数据处理不仅在数量上要求越来越大,而且在质量上也要求越来越高。

操作系统的稳定对数据库来说是十分紧要的,在数据库可操作平台上,oracle可在所有主流平台上运行,oracle数据库采用开放的策略目标,它使得客户可以选择一种最适合他们特定需要的解决方案。客户可以利用很多种第三方应用程序、工具。对开发商来说是很大的支持。而sql server却只能在windows上运行了,这个就显得比较单调了,但sql sever在window平台上的表现,和windows操作系统的整体结合程度,使用方便性,和microsoft开发平台的整合性都比oracle强的很多。但windows操作系统的稳定性及可靠性大家是有目共睹的,再说microsoft公司的策略目标是将客户都锁定到windows平台的环境当中,只有随着windows性能的改善,sql server才能进一步提高。从操作平台这点上oracle是完全优胜于sql server的了。
从资料上可以看到,oracle的安全认证获得最高认证级别的iso标准认证,而sql server并没有获得什么安全认证。这方面证明了oracle的安全性是高于sql server的。

购买一个产品,首先考虑的当然是产品的性能了,当考虑性能的同时当然少不了究竟要花多少钱在这产品也是个很关键的问题。要建立并运行一个数据库系统。不仅仅包含最初购置软件、硬件的费用,还包含了培训及以后维护的费用。orcale数据库的价格是远比sql server数据库要高,为什么oracle数据库比sql server数据库价格上要高出那么多,一方面oracle的初始花费相对较高,特别是在考虑工具软件的时候,oracle很多工具软件需要另外购买,与microsoft提供免费的sql server工具软件相比,oracle更显价格的不菲。但由于sql server只能在windows下运行的原因,普遍认为sql server数据库的可靠性是比较差的。oracle的性能优势体现在他的多用户上,而sql server的性能优势在多用户上就显得力不从心了。

操作上sql server明显要比orcale简单,如果你用过java和dotnet的开发平台,区别的基本就是oracle和sql server不同,oracle的界面基本是基于java的,大部分的工具是dos界面的,甚至sqlplus也是, sql server是跟vb一样,全图形界面,很少见到dos窗口。sql server中的企业管理器给用户提供一个全图形界面的集成管理控制台来集中管理多个服务器。oracle也有自己的企业管理器,而且它的性能在某些方面甚至超过了sql server的企业管理器,但它安装较为困难。
orcale数据库和sql server数据库那个更快?其实是一个很难答的问题,因为存在许多不定因素,包括处理类型、数据分布以及硬件基础设施等。
sql server 2000是一个具备完全web支持的数据库产品,提供了可扩展标记语言核心支持以及internet上和防火墙外进行查询的能力,具有可伸缩性、灵活性、扩充性好,而且价格便宜等特点,而oracle则有着可靠安全性,速度比sql server快上百倍,但其价格在实施中却比sql server它高出了几百倍。
其实各行业考虑选择那种数据库,是由数据库的特点以及根据自己的业务需求和基础设施综合考虑来决定的。

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com