SQLServer与Oracle的对照

    近期去铁科院面试,项目组长问了我这样一下问题:SQLServer与Oracle的差别是什么?从进入软件行业。从開始CS的编码到BS的编码过程中使用的都是SQLServer。在半年前開始敲DRP的过程中才接触到Oracle。当时给我的感觉Oracle太庞大了,或许对新奇的事物都是这样的感觉吧。以下我就来具体的介绍一下:

   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='登录password'
                 
          改动登陆账户:
                 alter Login 登陆名称 with name='新登录名称' and password='新登陆password'
          禁用/启用登陆账号
                 alter Login 登录名称 disable(禁用)/enable(启用)
          删除登陆账号
                 drop Login 登录名称
                 
           2、创建用户:
            create user username for/from Login 登陆名称
            
            改动username
            alter user username with name='新username'
            
           删除username
            drop user username
            
            授权限
            grant select/update/delete/insert on 表名 to username
              
            
         oracle中:
        
            创建用户语法:
                  create user username
                  identified by password
                  default tablespace users
                  temporary tablespace temp
                  quota 10M on users
                  
              改动password:
                  alter user username identified by 新password
                  
              授予权限:
                  grant create session to username
                  
               删除用户
                  drop user username cascade;
                  
                  

posted @ 2016-03-10 21:14  phlsheji  阅读(854)  评论(0编辑  收藏  举报