sql server 与 oracle的区别

转载于:http://blog.csdn.net/it_fengli/article/details/8213839

--sql server 与  oracle的区别:

--DBMS 数据库管理系统

--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-04 03:36:46

sql server 与 oracle的区别的相关文章

sql server 与 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

【转】SQL Server与Oracle的区别

转自:http://soft.chinabyte.com/database/255/12258255.shtml SQL Server与Oracle的区别 2012-02-10 00:00 中国IT实验室 佚名 关键字:Oracle 随着信息技术的飞速发展,数据处理不仅在数量上要求越来越大,而且在质量上也要求越来越高.Oracle数据库在大多数企业中受到广泛使用,而SQL Server数据库也因为和Windows的联系,在企业中的使用也是非常广泛. 操作系统的稳定对数据库来说是十分紧要的,在数据

C#连接Access、SQL Server、Oracle、MySQL、DB2和SyBase数据库的代码集

C#连接六类数据库的代码集 本文列出了C#连接Access.SQL Server.Oracle.MySQL.DB2和SyBase六种不同数据库的程序源码和需要注意的点. 1.C#连接Access 程序代码: Code using System.Data;using System.Data.OleDb; .. string strConnection="Provider=Microsoft.Jet.OleDb.4.0;"; strConnection+[email protected]&

SQL Server和Oracle数据库索引介绍

SQL Server和Oracle数据库索引介绍 1 SQL Server中的索引 索引是与表或视图关联的磁盘上结构,可以加快从表或视图中检索行的速度.索引包含由表或视图中的一列或多列生成的键.这些键存储在一个结构(B 树)中,使 SQL Server 可以快速有效地查找与键值关联的行. 表或视图可以包含以下类型的索引: 聚集索引 聚集索引根据数据行的键值在表或视图中排序和存储这些数据行.索引定义中包含聚集索引列.每个表只能有一个聚集索引,因为数据行本身只能按一个顺序排序. 只有当表包含聚集索引

使用 Oracle GoldenGate 在 Microsoft SQL Server 和 Oracle Database 之间复制事务

使用 Oracle GoldenGate 在 Microsoft SQL Server 和 Oracle Database 之间复制事务 作者:Nikolay Manchev 分步构建一个跨这些平台的简单事务复制示例. 2011 年 8 月发布 大多数关注数据复制的 Oracle 技术专家都熟悉 Oracle Streams.在 2009 年之前,Streams 一直是推荐使用的最流行的 Oracle 数据分发技术. 2009 年 7 月,Oracle 收购了 GoldenGate 这一数据库复

SQL Server连接Oracle详细步骤

http://blog.csdn.net/weiwenhp/article/details/8093105 我们知道SQL Server和Oracle其实很多原理都类似.特别是一些常用的SQL语句都是按照标准来.所以它们也可以有一定的互操作性的.这里讲一下,怎么配置让SQL Server连接一个Oracle.然后你在SQL Server中也能查看Oracle中表的内容. 我先说下我使用的环境: 操作系统: win7 64  ,SQL Server 2008 ,Oracle  Server 11g

关于sql server远程访问Oracle数据库 OpenQuery查询返回多条数据的问题

在Sql Server远程访问Oracle 中的数据库表时: 远程语法通常为: select * from OpenQuery(Oracle链接服务器名称,‘查询语句’) eg: select * from OPENQUERY(QTX,'select * from student') 有些情况下只会返回student表一条数据 第一条 解决方法:数据源ODBC中 选择系统DNS 时,新建系统数据源 选择的对应驱动应该为Oracle Instant Client Dricver  这个驱动需要安装

SQL Server往Oracle导入数据

        在windows下的Oracle中创建用户 Oracle下创建用户赋予权限,在终端中启动 SQL Plus. 创建用户+密码(用户:sa 密码:lenovo) SQL> create user sa identified by lenovo; 单独赋予用户权限 SQL> grant create session to sa; SQL> grant create table to sa; SQL> grant create sequence to sa; SQL>

SQL Server、Oracle和MySQL判断NULL的方法

SQL Server.Oracle和MySQL判断NULL的方法 本文讲述SQL Server.Oracle.MySQL查出值为NULL的替换. 在SQL Server Oracle MySQL当数据库中查出某值为NULL怎么办? 1.MSSQL: ISNULL() 语法 Java代码 复制代码代码如下: ISNULL ( check_expression , replacement_value ) ISNULL ( check_expression , replacement_value )