【Mysql】Mysql儲存過程學習

小亮520cl發表於2016-02-24

引數

  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/,如需轉載,請註明出處,否則將追究法律責任。

相關文章