oracle sql字符串游标,[原创]sqlserver含游标的过程转oracle经验

[原创]sqlserver含游标的过程转oracle经验

第一步:将整体构架变过来,sqlserver是直接建立proc的,而oracle出于兼容性考虑一般先建立package,然后在package中包含proc。变量声明也有所不同,oracle每句结尾要增加;下面将体现。

MSSQL  ALTER PROC procname --创建和修改要分开写

@p_varname vartype --过程参数

as

begin

_declare@varname vartype --过程内临时变量

sql --语句主体 返回结果可以直接用select写出来

end

ORACLE  create or replace package P_name --包头

is

TYPE T_CURSOR IS REF CURSOR;   --返回结果须用游标返回,这一点和mssql不一样,这里定义动态游标

PROCEDURE proc_name

(

p_varname IN vartype,

Re_CURSOR OUT T_CURSOR

);

end P_name;

create or replace package body P_name --包体,需要和包头分开执行

is

PROCEDURE proc_name

(

p_varname IN vartype,

Re_CURSOR out T_CURSOR

)

as

varname vartype;  --过程内临时变量

begin

sql  --sql主体

end proc_name;

end p_name;

第二步:创建游标,oracle中对于DDL以及要使用在游标中的sql语句来说,通常使用变量指代,一来符合规范,二来维护方便。这边分两种情况,通过游标查询以及通过游标插入/更新数据

MSSQL

游标查询 直接写select

游标插入/更新_declarecur CURSOR FOR select语句 ,OPEN cur,WHILE(@@FETCH_STATUS=0) BEGIN INSERT/UPDATE语句 值使用@varnameFETCH NEXT FROM cur INTO @varname END ,CLOSE cur,DEALLOCATE cur,

ORACLE

游标查询 sqlStr:='select语句' ;OPEN cur1 for sqlStr;

游标插入/更新 sqlStr:='select语句' ;OPEN cur1 for sqlStr;WHILE (cur1%found)   LOOPINSERT/UPDATE语句 值使用@varname ;FETCH cur1 INTO varname; END LOOP; CLOSE cur1

第三步:细节修改,主要是数据类型(典型的是sqlserver的varchar2和oracle的varchar)

格式转换(MS的CONVERT(VARCHAR(8),VAR,112)和ora的TO_DATE(VAR,'yymmdd'))

语句执行(MS的TRUNCATE TABLE tablename 和ORA的tmpSql varchar(1000);tmpSql:='';_execute immediate tmpSql;)

语句分隔(MS中begin-end多一些,ORA主要用分号;分隔)

变量引用(MS中不管定义还是引用都有在变量前面加@,ORA直接使用,另外ORA变量的赋值要使用:=,另外字符串sql语句中引用变量时,应采用'sql'''||var||'''sql'的格式)

oracle sqlserver 游标 过程 包 移

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值