SQLServer与Oracle的对照

it2025-06-02  92

    近期去铁科院面试,项目组长问了我这样一下问题: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;                                      

转载于:https://www.cnblogs.com/bhlsheji/p/5263499.html

相关资源:数据结构—成绩单生成器
最新回复(0)