mysql存储过程总结

1、所谓存储过程,实际上就是mysql批处理。过程是PROCEDURE的意思,Fortun语言的函数就是过程这个关键字。
2、存储过程中用到的变量,不能跟数据库字段名重复。比如
    UPDATE sku SET sku_name = sku_name WHERE sku_id = sku_id;
3、存储过程要放在某一个数据库中,但执行call存储过程时,不受数据库的影响。比如:
    call oms.sql_proc_calc_warehouse_fee();//
4、循环控制要注意退出判断,不要最后一句多执行一次。
    WHILE ex = 0 DO
        FETCH cur_owner INTO m_owner;
        IF ex = 0 THEN
            call oms.sql_proc_total_volumes(m_owner, m_wid, m_volumes);
            IF m_volumes > 0 THEN       //如果不在这里加判断的话,同样的记录会执行两次!
                SET m_fee = m_price * m_volumes;
                INSERT INTO bill_detail(created_at,is_deleted,user_id,warehouse_id,warehouse_name,money_type,money,year,month) VALUES(m_dt,0,m_owner,m_wid,m_wn,0,m_fee,yy,mm);
            END IF;
        END IF;
    END WHILE;
为什么会执行两次呢?DECLARE CONTINUE HANDLER FOR NOT FOUND SET ex = 1;
这句话的意思是,FETCH取不到数据的时候,将ex设置为1,从而退出while循环。对ex=0的判断在最前面,所以,就要执行两次。
DELIMITER //
CREATE PROCEDURE oms.sql_proc_test_time(IN skuid VARCHAR(20))
COMMENT 'procedure to create datetime'
BEGIN
    DECLARE yy,mm VARCHAR(20);
    DECLARE m_dt DATETIME;
    SET yy = year(curdate());
    SET mm = month(curdate());
    SET m_dt = now();
    UPDATE sku SET brand = yy WHERE id = skuid;
    UPDATE sku SET brand_name = mm WHERE id = skuid;
    UPDATE sku SET created_at = m_dt WHERE id = skuid;
    SELECT brand, brand_name FROM sku WHERE id = skuid;
END //

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

草根大哥

进军大神程序员路上,谢谢支持!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值