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

                  

                  

SQLServer与Oracle的对照的更多相关文章

  1. EntityFramework CodeFirst SQLServer转Oracle踩坑笔记

    接着在Oracle中使用Entity Framework 6 CodeFirst这篇博文,正在将项目从SQLServer 2012转至Oracle 11g,目前为止遇到的问题在此记录下. SQL Se ...

  2. 针对各主流数据mysql、sqlserver、oracle中文乱码问题。

    针对各主流数据mysql.sqlserver.oracle当以编码格式gbk存放数据时,要注意字符串类型的字段,要采用宽字符串nvarchar存放,前提是当你的应用程序是utf8编码,而数据库是gbk ...

  3. SQLServer访问Oracle查询性能问题解决

    原文:SQLServer访问Oracle查询性能问题解决 1. 问题 系统有个模块,需要查询Oracle数据库中的数据.目前是通过建立链接服务器实现的. SQLServer访问Oracle实现 可参考 ...

  4. C#操作SqlServer MySql Oracle通用帮助类Db_Helper_DG(默认支持数据库读写分离、查询结果实体映射ORM)

    [前言] 作为一款成熟的面向对象高级编程语言,C#在ADO.Net的支持上已然是做的很成熟,我们可以方便地调用ADO.Net操作各类关系型数据库,在使用了多年的Sql_Helper_DG后,由于项目需 ...

  5. Access、SQLServer、Oracle常见SQL语句应用区别

    Access.SQLServer.Oracle常见SQL语句应用区别 关劲松 PMP 如果要兼容Access.SQL Server.Oracle三个数据库版本:我们在编写SQL语句的过程中,尽量使用一 ...

  6. spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置

    spring BasicDataSource 数据源配置 sqlserver数据库 oracle数据库 mysql数据jdbc配置 jdbc.properties 文件信息如下: ---------- ...

  7. 转 update关联更新在sqlserver和oracle中的实现

    sqlserver和oracle中实现update关联更新的语法不同,都可以通过inline view(内嵌视图)来实现,总的来说sqlserver更简单些. 测试例子如下: create table ...

  8. 利用Kettle进行SQLServer与Oracle之间的数据迁移实践

    Kettle简介 Kettle(网地址为http://kettle.pentaho.org/)是一款国外开源的ETL工具,纯java编写,可以在Windows.Linux.Unix上运行,数据抽取高效 ...

  9. [转]SQLServer和Oracle,存储过程区别,常用函数对比

    本文转自:http://www.cnblogs.com/neru/archive/2011/08/18/2144049.html 以前一直用sqlserver,只有很少的一点oracle的经验,现在要 ...

随机推荐

  1. tomcat优化-有改protocol 和 缓存 集群方案

    tomcat优化 在线上环境中我们是采用了tomcat作为Web服务器,它的处理性能直接关系到用户体验,在平时的工作和学习中,归纳出以下七种调优经验. 1. 服务器资源 服务器所能提供CPU.内存.硬 ...

  2. 顶尖数据挖掘辅助教学套件(TipDM-T6)产品白皮书

          顶尖数据挖掘辅助教学套件 (TipDM-T6)           产  品  说  明  书 广州泰迪智能科技有限公司 版权所有 地址: 广州市经济技术开发区科学城232号 网址: ht ...

  3. hdu4135Co-prime 容斥原理水题

    //问一个区间[a,b]与n互素的数的个数 //利用容斥原理可知 //在[a,b] 区间内对n的素数因子 //ans = 被一个数整除的数的个数 - 被两个数的最小公倍数整除的数的个数 + 被三个数的 ...

  4. Jquery揭秘系列:谈谈bind,one,live,delegate,on事件及实现

    在Jquery里面,我们用的最多的就是事件绑定了,事件绑定有多个函数.例如:bind,one,live,delegate,on等等. on() jQuery事件绑定.on()简要概述及应用 看源码发现 ...

  5. web Form 表单method="get" method="post" 区别

    get和post方法的不同 在B/S应用程序中,前台与后台的数据交互,都是通过HTML中Form表单完成的.Form提供了两种数据传输的方式——get和post.虽然它们都是数据的提交方式,但是在实际 ...

  6. HTML网页制作:[12]使用框架结构之frameset

    首先,我希望在你的目录下,有4个网页,各自显示不同的内容. 如图所示: 1.html显示“火影忍者” 2.html显示“英雄联盟” 3.html显示“嵌入式开发.网页开发.安卓开发” 4.html显示 ...

  7. 简述UITextField的属性和用法

    0.     enablesReturnKeyAutomatically 默认为No,如果设置为Yes,文本框中没有输入任何字符的话,右下角的返回按钮是disabled的. 1.borderStyle ...

  8. C#中in,out,ref,params的作用和区别

    ref和out的区别在C# 中,既可以通过值也可以通过引用传递参数.通过引用传递参数允许函数成员更改参数的值,并保持该更改.若要通过引用传递参数, 可使用ref或out关键字.ref和out这两个关键 ...

  9. Android 关于操作UI线程

    在非UI线程里访问 Android UI toolkit—这个在一个worker线程修改了 View .这会导致不可预期的结果,而且还难以调试. 为了修复这个问题,Android提供了几个方法从非UI ...

  10. JavaScript学习笔记(一)对象和属性

    对象属性的使用 JavaScript中的所有变量都可以当做对象使用,除了null和undefined. false.toString(); // 'false' [1, 2, 3].toString( ...