没头脑QAQ 2016-12-29 00:46 采纳率: 50%
浏览 980
已采纳

跪求大神把这这段oracle的存储过程改成mysql的

CREATE OR REPLACE PROCEDURE count_busniess_type (
v_c_04 out number,
v_sum_04 out boc_payinfo.ORDERAMOUNT%TYPE,

v_type in varchar,

v_date_start char,

v_date_end char,

v_mech_no varchar,

v_amount_sum out number,

v_order_sum out number

)
as

BEGIN

select count(*),sum(ORDERAMOUNT) into v_c_04,  v_sum_04 from boc_payinfo where PROCSTATE = '04' and chltype like '%' || v_type ||'%' and MECHDATE >= v_date_start and MECHDATE <= v_date_end and mechno like '%' || v_mech_no ||'%';

IF v_c_04 = 0 THEN
v_sum_04 := 0;
END IF;

v_amount_sum := v_sum_04 + v_sum_02 + v_sum_03 + v_sum_05 + v_sum_06 + v_sum_07 + v_sum_08 + v_sum_99 + v_sum_14;
v_order_sum := v_c_04 + v_c_02 + v_c_03 + v_c_05 + v_c_06 + v_c_07 + v_c_08 + v_c_99 + v_c_14;

END count_busniess_type;

  • 写回答

1条回答 默认 最新

  • Aaronhugo 2016-12-29 02:09
    关注

    1,把参数格式从:v_c_04 out number变成 out v_c_04 number; 即把位置换一下。
    2,把sql里面的like语句换成:chltype LIKE CONCAT('%',v_type , '%')
    3,把里面的 v_sum_xx:= 变成 set v_sum_xx= xx;

    其他都一样的。

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

报告相同问题?

悬赏问题

  • ¥15 孟德尔随机化结果不一致
  • ¥20 求用stm32f103c6t6在lcd1206上显示Door is open和password:
  • ¥15 apm2.8飞控罗盘bad health,加速度计校准失败
  • ¥15 求解O-S方程的特征值问题给出边界层布拉休斯平行流的中性曲线
  • ¥15 谁有desed数据集呀
  • ¥20 手写数字识别运行c仿真时,程序报错错误代码sim211-100
  • ¥15 关于#hadoop#的问题
  • ¥15 (标签-Python|关键词-socket)
  • ¥15 keil里为什么main.c定义的函数在it.c调用不了
  • ¥50 切换TabTip键盘的输入法