- 4
- 0
- 约9.18千字
- 约 17页
- 2017-05-06 发布于北京
- 举报
SQLServervsOracle存储过程语法转换1﹒2
一、SQL Server vs Oracle 简单语法比较
此为本人将ORACLE 函数和存储过程转换为SQL SERVER遇到的一些语法问题的经验总结,肯定不能包括所有的语法不同点。
注: 简单的语法异同
1、SQL SERVER变量 必须以@开头。
2、SQL SERVER语句后不需要写分号结束符。
3、oracle变量类型number 可以修改为sql server的decimal
4、oracle变量类型varchar2 可以修改为sql server的varchar
5、SQL SERVER定义变量 及传递参数,最好加上参数大小数值,例如:varchar(50)
5、SQL SERVER 不能用ROWID, ROWNUM (但可以用TOP代替)
6、oracle里的nvl函数,在SQL SERVER里使用ISNULL函数取代
7、SQL SERVER自定义函数不允许修改全局表数据(只允许修改自定义函数范围内表数据), 所以发生表修改的 最好用存储过程实现而非函数。
1 create函数或存储过程异同点
Oracle 创建函数或存储过程 一般是 create or replace ……
SQL SERVER 则是在创建之前加一条语句,先判断是否已经存在,如果存在删除已有的函数或存储过程。
函数语句
if exists (select * from dbo.sysobjects where id = object_id(N[dbo].[函数名]) and xtype in (NFN, NIF, NTF))
drop function [dbo].[函数名]
GO
存储过程
if exists (select * from dbo.sysobjects where id = object_id(N[dbo].[存储过程名]) and OBJECTPROPERTY(id, NIsProcedure) = 1)
drop procedure [dbo].[存储过程名]
GO
2 结构异同点
ORACLE
Create 部分
IS 定义部分
BEGIN … END; 实现部分
SQL SERVER
Create 部分
AS 定义和实现部分 (AS 下面的代码一般用BEGIN … END 包含)
3 调用参数
ORACLE输入参数 参数名In 参数类型
ORACLE输出参数 参数名Out 参数类型
SQL SERVER输入参数 参数名 参数类型 IN(IN可以不写,系统默认)
SQL SERVER输出参数 参数名 参数类型 OUTPUT
4 变量命名及赋值
ORACLE
1、变量名 随便取
2、定义格式为 变量名 变量类型;
3、给变量赋值为 变量名 := 值;
SQL SERVER
1、变量名前面一般加@
2、定义格式为 declare 变量名 变量类型
3、SET变量名 =变量类型
5 IF语句
ORACLE
IF … THEN
….
ELSE
...
END IF;
SQL SERVER
IF ... BEGIN
……
END
ELSE BEGIN
……
END
或者
IF ...
BEGIN
……
END
ELSE
BEGIN
……
END
6 case语句
ORACLE
IF … THEN
….
ELSE
...
END IF;
SQL SERVER
IF ... BEGIN
……
END
ELSE BEGIN
……
END
或者
IF ...
BEGIN
……
END
ELSE
BEGIN
……
END
7 游标的定义及使用 及循环操作
ORACLE定义游标
CURSOR CurA IS SELECT a FROM tab where … ;
SQL SERVER定义游标
DECLARE CurA CURSOR LOCAL FOR SELECT a FROM tab where … ;
ORACLE使用游标
Open CurA; -- 打开游标
Fetch CurA Into ISUserUnitPri;
IF CurA%NOTFOUND THEN -- 注:如果为CurA%FOUND,看下面相同位置注释
ISUserUnitPri := 1;
END IF;
Close CurA; -- 关闭游标
SQL SERVER使用游标
Open CurA -- 打开游标
Fetch next from CurA Into @ISUserUnitPri
IF @@fetch
您可能关注的文档
- photoshop如何抹除照片中多余的人及物.doc
- photoshop图像合成–菠萝城堡.doc
- Photoshop快速把人像转为黑白素描画[2009–9–4].doc
- Photoshop打造完美室内设计效果图.doc
- Photoshop对照片后期美容的1些技巧.doc
- Photoshop把人物头像转为高对比水彩素描.docx
- Photoshop教程〔超链接〕.doc
- Photoshop抠图实例教程︰怀恋抽出滤镜.doc
- Photoshop欠暴偏色宝宝照片处理.doc
- photoshop文字特效︰创建高光和阴影效果的3D文字.doc
- 2025-2026学年天津市和平区高三(上)期末数学试卷(含解析).pdf
- 2025-2026学年云南省楚雄州高三(上)期末数学试卷(含答案).pdf
- 2025-2026学年甘肃省天水市张家川实验中学高三(上)期末数学试卷(含答案).docx
- 2025-2026学年福建省厦门市松柏中学高二(上)期末数学试卷(含答案).docx
- 2025-2026学年广西钦州市高一(上)期末物理试卷(含答案).docx
- 2025-2026学年河北省邯郸市临漳县九年级(上)期末化学试卷(含答案).docx
- 2025-2026学年河北省石家庄二十三中七年级(上)期末历史试卷(含答案).docx
- 2025-2026学年海南省五指山市九年级(上)期末化学试卷(含答案).docx
- 2025-2026学年河北省唐山市玉田县九年级(上)期末化学试卷(含答案).docx
- 2025-2026学年河北省邢台市市区九年级(上)期末化学试卷(含答案).docx
最近下载
- (苏教版)数学五年级上册寒假“天天练”作业设计,含30份题组,附参考答案.doc
- 有限空间作业注意事项.pptx VIP
- 从明代土地产权制度弊端剖析古代土地制度的困境与启示.docx
- 工贸企业常见安全生产隐患诊断检查指导书.pdf VIP
- 麓山景区2006-2020详细规划.doc VIP
- 《地基与基础培训》课件.ppt VIP
- 2026年村卫生室基本公共卫生服务工作计划.docx VIP
- 阿姆斯壮Armstrong--THE BRAIN® DMC80再循环水温控制样本.pdf
- 《地下工程建设疏干排水水资源论证导则》.pdf VIP
- GB 17167-2025用能单位能源计量器具配备和管理通则.pdf
原创力文档

文档评论(0)