MySQL存儲(chǔ)過(guò)程是一組預(yù)編譯SQL語(yǔ)句的集合,并且它們可以被封裝在存儲(chǔ)過(guò)程內(nèi)部。它可以接收參數(shù)以及使用參數(shù)的值來(lái)進(jìn)行操作。下面將介紹如何使用參數(shù)的值來(lái)創(chuàng)建MySQL存儲(chǔ)過(guò)程。
DELIMITER // CREATE PROCEDURE `get_employee_by_dept`(IN dept_name VARCHAR(50)) BEGIN SELECT * FROM employees WHERE department = dept_name; END // DELIMITER ;
上面的代碼創(chuàng)建了一個(gè)名為`get_employee_by_dept`的MySQL存儲(chǔ)過(guò)程,它接收一個(gè)名為`dept_name`的參數(shù)。這個(gè)參數(shù)是VARCHAR類型,并且最大長(zhǎng)度為50個(gè)字符。下面是如何使用這個(gè)存儲(chǔ)過(guò)程:
CALL `get_employee_by_dept`('engineering');
上面的代碼展示了如何調(diào)用`get_employee_by_dept`存儲(chǔ)過(guò)程,并且傳遞參數(shù)`engineering`。存儲(chǔ)過(guò)程用這個(gè)參數(shù)來(lái)進(jìn)行篩選,并且只返回部門名稱為`engineering`的雇員記錄。
除了IN參數(shù),在MySQL存儲(chǔ)過(guò)程中還有其他類型的參數(shù)可以使用。OUT參數(shù)允許存儲(chǔ)過(guò)程返回一個(gè)值給調(diào)用程序。INOUT參數(shù)是一個(gè)輸入輸出參數(shù),允許外部程序修改參數(shù)的值。下面是一個(gè)允許調(diào)用程序傳遞值給存儲(chǔ)過(guò)程,并且存儲(chǔ)過(guò)程返回這個(gè)值的例子:
DELIMITER // CREATE PROCEDURE `square`(IN number INT, OUT result INT) BEGIN SET result = number * number; END // DELIMITER ;
上面的代碼創(chuàng)建了一個(gè)名為`square`的存儲(chǔ)過(guò)程,它接收一個(gè)名為`number`的整數(shù)參數(shù)。它還有一個(gè)名為`result`的OUT參數(shù),它將返回結(jié)果。當(dāng)調(diào)用這個(gè)存儲(chǔ)過(guò)程時(shí),程序必須提供一個(gè)變量來(lái)接收結(jié)果:
DECLARE output INT; CALL `square`(10, output); SELECT output;
上面的代碼將返回100,因?yàn)檎{(diào)用`square`并傳遞參數(shù)`10`會(huì)計(jì)算`10 * 10`,并將結(jié)果賦值給OUT參數(shù)。