2 zhxia23 zhxia23 于 2013.12.09 16:10 提问

如何把下面的oracle中的存储过程转换成sql的?

create or replace procedure BJ_MAXCASENO_Get(InCount in number,
OutMaxCaseNO out number) as
tem number;
begin
select max(caseno) into tem from BJ_MAXCASENO;
if tem is null then
tem := 0;
-- 没有数据时新增0进入
insert into BJ_MAXCASENO (CASENO) VALUES (0);
end if;
tem := tem + InCount;
update BJ_MAXCASENO set CaseNO = tem;
OutMaxCaseNO := tem;

end BJ_MAXCASENO_Get;

1个回答

a_liujian
a_liujian   2013.12.09 17:37
已采纳

你这个逻辑即需要insert,又需要update,即需要输入参数,又有输出参数,通过sql是没法写出的.
从你的存过分析来看,你只是对BJ_MAXCASENO表的max(CASENO)+InCount做更新和查询操作,
可以考虑以下这种实现方式:如果是空则新增0近入,如果非空,也新增一条max(caseno)+'InCount'近入,insert into BJ_MAXCASENO
(CASENO)
select (case
when max(CASENO) is null then
0
else
max(CASENO) + 'InCount'
end) as CASENO
from BJ_MAXCASENO;

当然查询最大值就又得需要一条查询sql语句:select max(caseno) from BJ_MAXCASENO

PS:以上内容,纯当参考,

Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!