삽입 후 다른 테이블의 열을 업데이트하는 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!