Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

OUT 매개변수를 사용하여 MySQL 저장 프로시저를 생성하려면 어떻게 해야 합니까?


이해하기 위해 다음 값을 갖는 'student_info'라는 테이블을 사용하고 있습니다 -

mysql> Select * from student_info;
+------+---------+------------+------------+
| id   | Name    | Address    | Subject    |
+------+---------+------------+------------+
| 101  | YashPal | Amritsar   | History    |
| 105  | Gaurav  | Jaipur     | Literature |
| 110  | Rahul   | Chandigarh | History    |
| 125  | Raman   | Shimla     | Computers  |
+------+---------+------------+------------+
4 rows in set (0.00 sec)

이제 다음 쿼리의 도움으로 주제 이름을 매개변수로 제공하여 특정 주제의 총계를 계산하는 OUT 매개변수가 있는 저장 프로시저를 생성합니다.

mysql> DELIMITER // ;
mysql> Create Procedure subjects (IN S_Subject VARCHAR(25), OUT total INT)
   -> BEGIN
   -> SELECT count(subject)
   -> INTO total
   -> FROM student_info
   -> WHERE subject = S_subject;
   -> END //
Query OK, 0 rows affected (0.00 sec)

mysql> DELIMITER ;

'S-Subject'는 계산하고자 하는 과목의 개수인 IN 파라미터이고, 'total'은 특정 과목에 대한 과목의 개수를 저장하는 OUT 파라미터입니다.

mysql> CALL subjects('Computers', @total);
Query OK, 1 row affected (0.02 sec)

mysql> Select @total;
+--------+
| @total |
+--------+
|      1 |
+--------+
1 row in set (0.01 sec)

mysql> CALL subjects('History', @total);
Query OK, 1 row affected (0.00 sec)

mysql> Select @total;
+--------+
| @total |
+--------+
|      2 |
+--------+
1 row in set (0.00 sec)