집 >데이터 베이스 >MySQL 튜토리얼 >mysql은 저장 프로시저를 사용한다
MySQL은 널리 사용되는 관계형 데이터베이스 관리 시스템으로, 저장 프로시저 사용을 지원하는 데 있습니다. 저장 프로시저는 매개 변수를 받아들이고 MySQL 서버에 저장되는 실행 가능한 SQL 문의 집합입니다. 반복 작업을 보다 효율적으로 수행하기 위해 응용 프로그램이나 기타 저장 프로시저에서 저장 프로시저를 호출할 수 있습니다. 이번 글에서는 MySQL 저장 프로시저의 사용법을 살펴보겠습니다.
1. 저장 프로시저 생성
MySQL에서는 CREATE PROCEDURE 문을 통해 저장 프로시저를 생성할 수 있습니다. 구문은 다음과 같습니다.
CREATE PROCEDURE procedure_name ([parameter_list]) BEGIN -- SQL statements END;
매개변수 목록은 0개 이상의 입력(IN) 또는 출력(OUT) 매개변수를 지정하는 선택적 항목입니다. 입력 매개변수는 데이터를 저장 프로시저에 전달하는 데 사용되고, 출력 매개변수는 저장 프로시저에서 데이터를 반환하는 데 사용됩니다.
그런 다음 SQL 문을 저장 프로시저에 넣어야 합니다. 예:
CREATE PROCEDURE get_customer_info (IN customer_id INT) BEGIN SELECT * FROM customers WHERE customer_id = customer_id; END;
이 프로세스에서는 입력 매개변수 customer_id를 고객 정보 필터로 사용하여 고객 테이블에서 반환하는 get_customer_info라는 저장 프로시저를 생성합니다. 지정된 ID로.
2. 저장 프로시저 호출
저장 프로시저가 생성되면 CALL 문을 통해 호출할 수 있습니다. 예:
CALL get_customer_info(1);
이 문은 get_customer_info 저장 프로시저를 호출하고 값 1을 customer_id 매개 변수로 전달합니다. 고객 테이블에 ID 1의 고객 정보가 반환됩니다.
3. 저장 프로시저의 변수
SQL 문과 마찬가지로 저장 프로시저도 변수를 사용하여 값을 저장할 수 있습니다. 저장 프로시저 내에서 DECLARE 문을 통해 변수를 선언할 수 있습니다. 예:
CREATE PROCEDURE get_customer_info (IN customer_id INT) BEGIN DECLARE customer_name VARCHAR(255); SELECT name INTO customer_name FROM customers WHERE customer_id = customer_id; END;
이 절차에서는 customer_name이라는 변수를 선언하고 이를 사용하여 SELECT 문의 "name" 열에 값을 저장했습니다. 마지막으로 SELECT 문의 INTO 절을 통해 변수에 값을 할당할 수 있습니다.
4. 조건부 논리 및 루프
다른 프로그래밍 언어와 마찬가지로 저장 프로시저에는 조건부 논리 및 루프가 포함될 수 있습니다. 예:
CREATE PROCEDURE insert_customer (IN customer_name VARCHAR(255), IN customer_email VARCHAR(255)) BEGIN DECLARE customer_id INT; SELECT MAX(customer_id) + 1 INTO customer_id FROM customers; IF customer_id IS NULL THEN SET customer_id = 1; END IF; INSERT INTO customers (customer_id, name, email) VALUES (customer_id, customer_name, customer_email); END;
이 프로세스에서는 MAX 함수를 사용하여 현재 최대 고객 ID를 확인한 다음 여기에 1을 더합니다. 현재 고객이 없으면 ID는 1로 설정됩니다. 그런 다음 INSERT 문을 사용하여 고객 테이블에 새 레코드를 삽입할 수 있습니다.
저장 프로시저에는 WHILE 루프, IF-ELSE 문, GOTO 문 등과 같은 다른 구조도 포함될 수 있습니다.
5. 효율성 측정
저장 프로시저 사용의 주요 장점 중 하나는 쿼리 효율성을 향상시킬 수 있다는 것입니다. 저장 프로시저는 MySQL 서버에서 컴파일되고 캐시되므로 일반 SQL 문보다 빠릅니다. 저장 프로시저를 사용하면 SQL Server와 애플리케이션 간의 네트워크 트래픽과 대기 시간을 줄여 쿼리 속도를 높일 수 있습니다.
6. 요약
저장 프로시저는 MySQL이 제공하는 강력한 도구 중 하나이며, 이를 통해 MySQL 서버에서 재사용 가능한 SQL 코드 블록을 실행할 수 있습니다. 저장 프로시저에는 복잡한 애플리케이션 논리를 처리하기 위한 조건부 논리와 루프가 포함될 수 있습니다. 저장 프로시저를 사용하면 쿼리 효율성을 높이고 MySQL 서버와 애플리케이션 간의 통신 오버헤드를 줄일 수 있습니다. 저장 프로시저는 MySQL의 핵심 기능 중 하나이며 효율적인 MySQL 애플리케이션을 개발하려면 저장 프로시저를 마스터하는 것이 중요합니다.
위 내용은 mysql은 저장 프로시저를 사용한다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!