>데이터 베이스 >MySQL 튜토리얼 >삽입 후 다른 테이블의 열을 업데이트하기 위해 MySQL 트리거를 만드는 방법은 무엇입니까?

삽입 후 다른 테이블의 열을 업데이트하기 위해 MySQL 트리거를 만드는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-24 04:12:11317검색

How to Create a MySQL Trigger to Update a Different Table's Column After an Insert?

삽입 후 다른 테이블의 열을 업데이트하는 MySQL 트리거

이 질문에는 BookingRequest 테이블의 상태 열을 업데이트하는 MySQL 트리거를 생성하는 방법이 포함됩니다. OccupiedRoom 테이블에 행을 삽입할 때.

초기 트리거 코드가 BookingRequest를 직접 업데이트하려고 시도했습니다. BookingRequest.idRequest와 NEW.idRequest 간의 비교를 사용하는 테이블입니다. 그러나 이 접근 방식은 실패했습니다.

이 문제를 해결하고 기능적 트리거를 생성하려면 아래 코드를 사용해야 합니다.

DELIMITER $$
CREATE TRIGGER occupy_trig
AFTER INSERT ON `OccupiedRoom` FOR EACH ROW
begin
       DECLARE id_exists Boolean;
       -- Check BookingRequest table
       SELECT 1
       INTO @id_exists
       FROM BookingRequest
       WHERE BookingRequest.idRequest= NEW.idRequest;

       IF @id_exists = 1
       THEN
           UPDATE BookingRequest
           SET status = '1'
           WHERE idRequest = NEW.idRequest;
        END IF;
END;
$$
DELIMITER ;

이 트리거는 @id_exists 변수를 활용하여 OccupiedRoom 테이블의 idRequest가 BookingRequest 테이블에 존재합니다. 그렇다면 BookingRequest 테이블의 상태 열을 '1'로 설정합니다.

트리거 내에서 자리 표시자 NEW를 사용하면 이제 삽입된 행의 idRequest와 해당 idRequest 간의 비교가 올바르게 수행됩니다. 예약 요청 테이블.

위 내용은 삽입 후 다른 테이블의 열을 업데이트하기 위해 MySQL 트리거를 만드는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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