저장 프로시저에서 준비된 명령문을 사용하려면 BEGIN 및 END 블록 내부에 작성해야 합니다. 이를 이해하기 위해 테이블 이름을 저장 프로시저의 매개 변수로 전달하여 테이블에서 모든 레코드를 가져올 수 있는 예제를 만들고 있습니다.
예시
mysql> DELIMITER //
mysql> Create procedure tbl_detail(tab_name Varchar(40))
-> BEGIN
-> SET @A:= CONCAT('Select * from',' ',tab_name);
-> Prepare stmt FROM @A;
-> EXECUTE stmt;
-> END //
Query OK, 0 rows affected (0.00 sec) 이제 테이블의 이름을 매개변수로 지정하여 이 프로시저를 호출하면 해당 테이블의 모든 레코드가 표시됩니다.
mysql> DELIMITER;
mysql> CALL tbl_detail('Student’);
+------+--------+
| Id | Name |
+------+--------+
| 1 | Ram |
| 2 | Shyam |
| 3 | Gaurav |
+------+--------+
3 rows in set (0.00 sec)
Query OK, 0 rows affected (0.03 sec)