【Mysql】Mysql存储过程学习

参数

  1. DELIMITER //                           申明结束符号
    DROP  PROCEDURE IF EXISTS p2;//        如果存在则删除
      
    CREATE PROCEDURE p2(v_uid INT,v_id INT)     创建过程带参数
    BEGIN


    SELECT * FROM `c_user_info` WHERE uid=v_uid AND id=v_id;     --主体部分


    END// 
    DELIMITER ;


    CALL p2(1475469,8);    ---调用








变量

  1. 如:
  2. DELIMITER //
    DROP  PROCEDURE IF EXISTS p2;//  
      
    CREATE PROCEDURE p2()
    BEGIN
    DECLARE v_id INT DEFAULT 8;   --申明变量 及默认值
    DECLARE v_uid INT;
    SET v_uid=1475469;            --变量赋值
    SELECT * FROM `c_user_info` WHERE uid=v_uid AND id=v_id;


    END// 
    DELIMITER ;

    CALL p2();   ---调用

If-else语句

  1. DELIMITER //

    CREATE PROCEDURE p7(IN param1 INT)  
    BEGIN  
     DECLARE v1 INT;  
     SET v1 = param1 + 1;  

  2.  IF v1 = 0 THEN  
       INSERT INTO t VALUES(17);  
     END IF;  

  3.  IF param1 = 0 THEN  
       UPDATE t SET s1 = s1 + 1;  
     ELSE  
       UPDATE t SET s1 = s1 + 2;  
     END IF;  
     
    END;// 
    DELIMITER ;


     CALL p7(0);
     CALL p7(-1);


Case-When语句

  1. 代码:
  2. DELIMITER //


    CREATE PROCEDURE p8(IN param1 INT)  
    BEGIN  
     
     
     CASE param1  
       WHEN 9  THEN INSERT INTO t VALUES(17);  
       WHEN 19 THEN INSERT INTO t VALUES(18);  
       ELSE INSERT INTO t VALUES(19);  
     END CASE;  
     
    END;// 
    DELIMITER ;


    CALL p8(9);
    CALL p8(19);



来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29096438/viewspace-1993760/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/29096438/viewspace-1993760/

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值