zhxia23 2013-12-09 08:10 采纳率: 100%
浏览 1997
已采纳

如何把下面的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_jian 2013-12-09 09: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:以上内容,纯当参考,

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看