oracle sql server语法,oracle与sqlserver的十大语法的区别

--DBMS 数据库管理系统--1.数据类型不同。--sql server 的数据类型:int,smallint,char,varchar,nchar,nvarchar,ntext,datetime,smalldatetime,money,decima,--float,bit……--oracle 的数据类型:number(p,s),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_idstart with 1increment by 1--使用序列实现自动增长:se_id.nextval--6.条件语句if……else……的语法不同--sql server中:if 条件begin…………endelsebegin…………end--oracle中:if 条件1 then…………;elsif 条件2 then…………;else…………;end if;--7.case语句的语法不同--sql server中:--select ....case.....(else)....end....语句select stuno '学号',casewhen 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 scorego--oracle中:declarenums number:=&nos;--&nos表示提示传入值begincase numswhen 100 thendbms_output.put_line('满分也,不错');when 90 thendbms_output.put_line('90分页很不错了');end case;end;--8.触发器创建语法不同--sql server中:--首先判断触发器是否已经存在if exists (select * from sys.sysobjects where name='tr_delete')--如果存在先删除drop trigger tr_deletego--创建触发器create trigger tr_deleteon bookInfoinstead of deleteas--定义变量declare @bookid intselect @bookid=Bookid from deleted---deleted执行删除语句( delete from BookInfo where BookId=1),自动生成的deleted表--删除与该图书的相关记录(先删除从表再删除主表)delete from borrowinfo where bookid=@bookiddelete from backinfo where bookid=@bookiddelete from BookInfo where BookId=@bookid--判断if @@error<>0beginprint '删除失败'rollback transactionendelsebeginprint '删除成功'endgodelete from BookInfo where BookId=1--oracle中:--创建触发器create or replace trigger tri_testbefore insert or update or deleteon table_name[for each row]---如果要使用 :new /:old 就必须使用行触发器declarenums varchar2(20);beginselect'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_namego--创建存储过程语句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)ascursor cursor_selisselect DepositSum,cardType,name,state from CurrentAccount where name like '%'||names||'%';dd number;cc number;nn varchar2(20);sta number;beginopen cursor_sel;loopfetch cursor_sel into dd,cc,nn,sta;dbms_output.put_line('存款金额:'||dd||'姓名:'||nn);exit when cursor_sel%notfound;end loop;close cursor_sel;end;--调用存储过程beginproc_selCurrent('a');end;--10.创建用户的方式不同--sql server中--1、创建登陆账号:sa-----123456create 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 usersalter user 用户名 identified by 新密码--授予权限:grant create session to 用户名drop user 用户名 cascade;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值