집 >데이터 베이스 >MySQL 튜토리얼 >mysql 저장 프로시저 생성
MySQL 저장 프로시저는 필요할 때 이러한 문을 실행하기 위해 호출할 수 있는 일련의 SQL 문을 데이터베이스에 저장하는 방법입니다. MySQL 저장 프로시저를 생성하려면 SQL 구문에 대한 기본 지식과 일부 프로그래밍 개념이 필요합니다.
이 기사에서는 MySQL 저장 프로시저를 생성하는 방법을 배우고 예제를 사용하여 기본 구문과 생성 프로세스를 설명합니다.
MySQL 저장 프로시저에서 사용하는 기본 구문은 다음과 같습니다.
CREATE PROCEDURE procedure_name() BEGIN -- SQL statements END;
그 중 CREATE PROCEDURE는 MySQL 저장 프로시저의 키워드이고, Procedure_name은 저장 프로시저의 이름입니다. BEGIN과 END 사이의 코드 블록은 저장 프로시저에 의해 실행되는 SQL 코드입니다.
다음은 학생 정보를 쿼리하는 데 사용되는 간단한 저장 프로시저의 예입니다.
CREATE PROCEDURE GetStudent() BEGIN SELECT * FROM Student; END;
저장 프로시저는 GetStudent라고 하며 해당 기능은 학생 데이터 테이블의 모든 데이터를 반환하는 것입니다.
MySQL 저장 프로시저는 입력 매개변수와 출력 매개변수를 허용할 수 있습니다. 입력 매개변수는 데이터를 저장 프로시저에 전달하는 데 사용되고, 출력 매개변수는 저장 프로시저에서 데이터를 반환하는 데 사용됩니다. 이 중 입력 매개변수와 출력 매개변수는 모두 저장 프로시저 생성 시 지정해야 합니다.
다음은 입력 매개변수가 있는 저장 프로시저의 예입니다.
CREATE PROCEDURE GetStudentByGrade(IN grade INT) BEGIN SELECT * FROM Student WHERE Grade = grade; END;
저장 프로시저는 GetStudentByGrade라고 하며 입력 매개변수 등급은 INT 유형입니다. 이 저장 프로시저가 호출되면 성적이 해당 학년과 같은 모든 학생 기록이 반환됩니다.
MySQL 저장 프로시저는 변수를 사용하여 데이터를 저장할 수도 있습니다. 이러한 변수는 저장 프로시저의 코드 블록 내에서 선언하고 사용할 수 있습니다.
다음은 변수가 있는 저장 프로시저의 예입니다.
CREATE PROCEDURE GetStudentByClassName(IN class_name VARCHAR(50), OUT student_count INT) BEGIN DECLARE class_id INT; SELECT ClassID INTO class_id FROM Class WHERE ClassName = class_name; SELECT COUNT(*) INTO student_count FROM Student WHERE ClassID = class_id; END;
저장 프로시저는 GetStudentByClassName이라고 하며 입력 매개변수 class_name과 출력 매개변수 Student_count라는 두 개의 매개변수가 있습니다. 먼저 변수 class_id를 선언한 다음 쿼리를 통해 변수 값을 가져옵니다. 마지막으로 쿼리를 통해 해당 수업과 관련된 학생 수를 계산하고 이를 Student_count 변수에 저장합니다.
MySQL 저장 프로시저는 제어 문을 사용하여 코드 블록의 실행을 제어할 수 있습니다. 일반적인 MySQL 저장 프로시저 제어 문에는 IF, CASE, WHILE 및 FOR가 포함됩니다.
다음은 IF 제어문을 사용하는 저장 프로시저의 예입니다.
CREATE PROCEDURE GetStudentByID(IN student_id INT) BEGIN DECLARE student_name VARCHAR(50); IF student_id <= 0 THEN SET student_name = 'Invalid ID'; ELSE SELECT StudentName INTO student_name FROM Student WHERE StudentID = student_id; END IF; SELECT student_name; END;
저장 프로시저는 GetStudentByID라고 하며 입력 매개변수 Student_id를 갖습니다. 먼저 변수 Student_name을 선언한 후 IF 제어문을 사용하여 입력한 학생 ID가 유효한지 확인합니다. 유효하지 않은 경우 "잘못된 ID"를 반환하고, 유효한 경우 데이터베이스를 쿼리하여 찾은 학생 이름을 Student_name 변수에 저장합니다.
MySQL을 사용하여 저장 프로시저 생성은 MySQL 명령줄 또는 MySQL Workbench를 통해 수행할 수 있습니다.
MySQL 명령줄에서 다음 명령을 사용하여 저장 프로시저를 만들 수 있습니다.
CREATE PROCEDURE procedure_name() BEGIN -- SQL statements END;
그런 다음 다음 명령을 사용하여 저장 프로시저를 호출할 수 있습니다.
CALL procedure_name();
MySQL Workbench에서 다음 단계를 사용하여 다음 작업을 수행할 수 있습니다. 저장 프로시저 생성:
저장 프로시저를 생성한 후 다음 명령을 사용하여 MySQL 명령줄에서 저장 프로시저를 호출할 수 있습니다.
CALL procedure_name();
MySQL Workbench에서 다음 단계를 사용하여 저장 프로시저를 호출할 수 있습니다.
MySQL 저장 프로시저는 SQL 코드를 데이터베이스에 저장하는 방법입니다. 저장 프로시저를 사용하면 복잡한 SQL 쿼리나 일반적으로 사용되는 SQL 코드 블록을 데이터베이스에 저장하여 나중에 다시 사용하거나 쿼리 효율성을 높일 수 있습니다. 이 문서에서는 MySQL 저장 프로시저의 기본 구문, 매개변수, 변수 및 제어문을 사용하는 방법, 저장 프로시저를 생성하고 호출하는 방법을 소개합니다. 이 기사가 MySQL 저장 프로시저를 이해하고 이를 실제 작업에 사용하여 데이터베이스 작업의 효율성을 높이는 데 도움이 되기를 바랍니다.
위 내용은 mysql 저장 프로시저 생성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!