>  기사  >  데이터 베이스  >  mysql 저장 프로시저 생성

mysql 저장 프로시저 생성

王林
王林원래의
2023-05-08 21:08:064158검색

MySQL은 대량의 데이터를 처리하는 데 탁월한 인기 있는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 저장 프로시저는 데이터 테이블과 상호 작용하고 쿼리에서 호출할 수 있는 재사용 가능한 코드 블록입니다.

이 글에서는 저장 프로시저를 생성하는 방법과 이를 MySQL에서 호출하고 사용하는 방법을 소개합니다.

1. 저장 프로시저 만들기

MySQL에서 저장 프로시저를 만들려면 일반적으로 다음 단계가 필요합니다.

1. MySQL 데이터베이스에 연결합니다.

2. CREATE PROCEDURE 명령을 실행하여 저장 프로시저를 정의합니다.

3. 저장 프로시저에서 논리를 정의합니다.

다음은 샘플 저장 프로시저입니다.

DELIMITER //
 
CREATE PROCEDURE getUsers()
BEGIN
    SELECT * FROM users;
END //
 
DELIMITER ;

위의 예에서는 사용자 테이블의 모든 레코드를 반환하는 getUsers라는 저장 프로시저를 정의했습니다.

여기서는 특별한 DELIMITER 명령을 사용하여 MySQL에게 저장 프로시저에서 SQL 쿼리를 분리하는 방법을 알려줍니다.

다음으로 CREATE PROCEDURE 명령을 사용하여 저장 프로시저를 정의합니다. 저장 프로시저의 이름, 수신 매개변수, 논리 및 출력 결과를 지정합니다.

저장 프로시저에서 BEGIN 및 END 명령을 사용하여 코드 블록에 논리를 넣었습니다.

마지막으로 DELIMITER 명령을 사용하여 SQL 쿼리에 대한 새 구분 기호를 지정합니다. 기본적으로 세미콜론(;)입니다. 이는 저장 프로시저에서 세미콜론을 사용하여 발생하는 구문 오류를 방지하기 위해 수행됩니다.

2. 저장 프로시저 호출

저장 프로시저를 생성하면 함수를 호출하는 것처럼 쿼리에서 참조할 수 있습니다. 예:

CALL getUsers();

저장 프로시저를 호출한 후 중간에 정의된 논리를 실행하고 결과를 반환합니다.

3. 매개변수 전달

저장 프로시저는 들어오는 매개변수를 사용하여 다양한 논리를 실행할 수 있습니다. 예는 다음과 같습니다.

DELIMITER //
 
CREATE PROCEDURE getUserById(IN id INT)
BEGIN
    SELECT * FROM users WHERE id = id;
END //
 
DELIMITER ;

위 예에서는 getUserById라는 저장 프로시저를 만들고 입력 매개 변수 ID를 정의했습니다. 저장 프로시저에서는 WHERE 문을 사용하여 ID를 일치시키고 레코드를 반환합니다.

저장 프로시저를 호출할 때 매개변수를 전달해야 합니다. 예:

CALL getUserById(1);

이렇게 하면 ID가 1인 사용자 레코드가 반환됩니다.

4. 저장 프로시저 수정

경우에 따라 저장 프로시저를 수정해야 할 수도 있습니다. 이것은 달성하기 쉽습니다. 다음 명령을 사용하여 기존 저장 프로시저를 수정할 수 있습니다.

ALTER PROCEDURE getUsers() 
BEGIN 
    SELECT * FROM users WHERE age > 18; 
END;

위 예에서는 18세보다 오래된 사용자 레코드만 반환하도록 getUsers 저장 프로시저를 수정했습니다. 이렇게 하면 다양한 비즈니스 요구에 맞게 저장 프로시저를 쉽게 수정할 수 있습니다.

5. 저장 프로시저 삭제

저장 프로시저가 더 이상 필요하지 않으면 다음 명령을 사용하여 삭제할 수 있습니다.

DROP PROCEDURE getUsers;

위 명령은 getUsers라는 저장 프로시저를 삭제합니다. 저장 프로시저를 삭제하면 해당 정의 및 관련 레코드가 영구적으로 삭제됩니다.

요약

저장 프로시저는 MySQL의 중요한 기능 중 하나입니다. 저장 프로시저를 생성하면 코드를 효율적으로 구성 및 재사용하고 복잡한 작업을 수행할 수 있습니다. 이 문서를 읽으면 이제 저장 프로시저를 작성하고 호출할 준비가 되었습니다. MySQL에 대해 자세히 알아보려면 공식 문서를 참조하세요.

위 내용은 mysql 저장 프로시저 생성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.