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  [email protected]

delete from backinfo where  [email protected]

delete from BookInfo where [email protected]

判断

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‘,@参数名[email protected]变量名 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;

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

时间: 2024-08-14 00:15:50

SQLServer与Oracle的对比的相关文章

SQLServer和Oracle的常用函数对比

---------数学函数 1.绝对值 S:select abs(-1) value O:select abs(-1)  value from dual 2.取整(大) S:select ceiling(-1.001) value O:select ceil(-1.001)  value from dual 3.取整(小) S:select floor(-1.001) value O:select floor(-1.001)  value from dual 4.取整(截取) S:select

达梦7的试用 与SQLSERVER的简单技术对比

达梦7的试用 与SQLSERVER的简单技术对比 达梦数据库公司推出了他们的数据库服务管理平台,可以在该平台使用达梦数据库而无须安装达梦7数据库 地址:http://online.dameng.com/ 说实话,第一眼看到还是感到很高大上的,毕竟ORACLE.MYSQL.SQLSERVER都没有推出数据库试用的云平台 其实其他数据库也应该学习一下达梦,做一个平台让大家有机会学习自家的数据库知识,虽然现在这个时代下载安装包比较容易,不过提供一个平台也是有好处的 达梦数据库文档下载:http://f

SqlServer 、Oracle 、MySql 的区别

一.sqlserver 优点: 易用性.适合分布式组织的可伸缩性.用于决策支持的数据仓库功能.与许多其他服务器软件紧密关联的集成性.良好的性价比等: 为数据管理与分析带来了灵活性,允许单位在快速变化的环境中从容响应,从而获得竞争优势.从数据管理和分析角度看,将原始数据转化为商业智能和充分利用Web带来的机会非常重要.作为一个完备的数据库和数据分析包,SQLServer为快速开发新一代企业级商业应用程序.为企业赢得核心竞争优势打开了胜利之门.作为重要的基准测试可伸缩性和速度奖的记录保持者,SQLS

存储过程之--MySQL与Oracle实现对比

存储过程之--MySQL与Oracle实现对比 1. 存储过程简介 我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储在数据库中,用户通过指定存储过程的名字并给定参数(如果该存储过程带有参数)来调用执行它. 一个存储过程是一个可编程的函数,它在数据库中创建并保存.它可以有SQL语句和一些特殊的控制结构组成.当希望在不同的应用程序或平台上执行相同的函数,或者封装特定功能时,存储过程是

SAP和Oracle的对比

SAP和Oracle的对比 SAP.Oracle和Microsoft是近十年来主要的ERP供应商.当你谈到ERP系统实现者时,它们就是这个产业的蓝筹股.它们是ERP系统的前三甲.也就是说,大多数人在选择ERP软件的时候,都是在考虑和比较它们的功能.本文中主要讨论的是基于Panorama咨询报告,SAP和Oracle的比较分析. 我主要关注供应商高层次特点的比较,并详细介绍它们竞争性的产品和技术.不幸的是,报告并没有告诉我们来自1600个被调查的对象反映何种业务.例如,它们是制造.财务服务或者服务

mysql、sqlserver、oracle三种数据库维护索引、外键、字段语法总结

mysql.sqlserver.oracle三种数据库维护索引.外键.字段语法总结 1.     MYSQL数据库 1)    创建索引 CREATE INDEX index_name ON table_name(column_list) CREATE UNIQUE INDEX index_name ON table_name(column_list) 修改表的方式添加索引 ALTER TABLE table_name ADD INDEX index_name(column_list) ALTE

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

原文:SQLServer访问Oracle查询性能问题解决 1. 问题 系统有个模块,需要查询Oracle数据库中的数据.目前是通过建立链接服务器实现的. SQLServer访问Oracle实现 可参考这篇文章http://www.cnblogs.com/gnielee/archive/2010/09/07/access-oracle-from-sqlserver.html 目前的查询语句就是一个简单的带where条件的查询语句,类似如下: SELECT * FROM LINKED_NAME..A

Mysql,SqlServer,Oracle主键自动增长的设置

1.把主键定义为自动增长标识符类型 MySql 在mysql中,如果把表的主键设为auto_increment类型,数据库就会自动为主键赋值.例如:   customers(id  auto_increment    , name (  customers(name)  id  customers; 以上sql语句先创建了customers表,然后插入两条记录,在插入时仅仅设定了name字段的值.最后查询表中id字段,查询结果为: 由此可见,一旦把id设为auto_increment类型,mys

关于sqlserver和oracle的一点感受

2012年使用了一点oracle,那个时候其实并不真正的了解这个数据库,所会的也就是利用toad做一些简单的管理,后来转战到sqlserver才开始对数据库这个东西有了一些了解.使用了sqlserver有一年多了,后来又开始使用了oracle了,让我一阵须臾,这回多少也该弄懂了oracle这个大大了吧,经过我的使用还真是发现了一些不同. sqlserver在存储中使用了不少的临时表,因为这有助于管理好数据的edit,但是这个方法在oracle中确实很少见的,因为对于oracle来说,临时表的建立