oracle与sql server的语法区别

1、oracle各类型字段描述

 

 

 

 

 

2、字段类型比较

 

 

 

3、常用函数比较

注:此处仅记录语法有区别的地方,更多丰富的语法请查看附件中的手册。
以下的exp为expression的缩写

 

 

 

4、 关于脏读

目前我们使用的sqlserver 数据库,在查询数据时,都要求在select语句中后面跟一个(nolock)或(with nolock)来保证读取大表时不影响其它程序进程的数据操作。
在oracle中,目前还不允许脏读的方式,在每次select 后,读到的数据都是已经commit的数据,所以为了避免读取数据的不准确,程序中如果有比较耗时的sql操作,尤其是在insert 和 update后,尽量减小事务,而且要在事务结束后及时commit。

e) 表(主键、外键、CHECK、UNIQUE、DEFAULT、INDEX)

在创建表及其主键、外键、CHECK、UNIQUE、DEFAULT、INDEX时,SQL SERVER 与ORACLE的语法大致相同。主要区别如下:

Oracle定义表字段的default属性紧跟字段类型之后,如下:

Create table MZ_Ghxx

( ghlxh number primay key ,

rq date default sysdate not null,

….

)

而不能写成

Create table MZ_Ghxx

( ghlxh number primay key ,

rq date not null default sysdate,….

)

 

 

 

 

 

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 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='登陆密码'

--修改登陆账户:
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;

 

posted @   znyzny  阅读(1172)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下
点击右上角即可分享
微信分享提示