수정되지 않은 행에서 MySQL 트리거가 실행되지 않도록 방지
MySQL 트리거는 삽입, 업데이트, 삭제 등 테이블에서 특정 작업이 발생할 때 실행됩니다. 그러나 기본적으로 "업데이트 후" 트리거는 테이블 행이 변경되지 않은 경우에도 활성화됩니다.
변경 사항이 없는데도 "업데이트 후" 트리거가 실행되는 이유는 무엇입니까?
업데이트된 행에서 변경 사항을 감지하는 일반적인 방법은 행의 '새' 버전과 '이전' 버전 간의 개별 열 값을 비교하는 것입니다. 그러나 테이블의 열 수가 증가하면 이 접근 방식은 지루해지고 오류가 발생하기 쉽습니다.
해결책: 행 타임스탬프를 활용하여 변경 사항 식별
이 문제를 해결하는 깔끔한 방법은 행 타임스탬프 열을 사용하는 것입니다. MySQL은 각 행에 대해 생성 타임스탬프와 업데이트 타임스탬프라는 두 개의 타임스탬프 열을 유지합니다. 이러한 타임스탬프는 행이 삽입되거나 업데이트될 때마다 자동으로 업데이트됩니다.
타임스탬프 비교를 기반으로 트리거 실행
새 타임스탬프와 기존 타임스탬프를 비교하여 행이 변경되었는지 확인할 수 있습니다. 다음 트리거 코드는 이 접근 방식을 보여줍니다.
CREATE TRIGGER ins_sum AFTER UPDATE ON foo FOR EACH ROW BEGIN IF NEW.ts <> OLD.ts THEN -- 已进行更改;执行触发器主体 END IF; END;
이 트리거에서 "NEW.ts"와 "OLD.ts"는 각각 새로운 타임스탬프 값과 이전 타임스탬프 값을 나타냅니다. 값이 다르면 변경이 발생하고 트리거 본문이 실행됩니다.
예
다음 예를 고려해 보세요.
CREATE TABLE foo (a INT, b INT, ts TIMESTAMP); -- 插入一些行 INSERT INTO foo (a, b) VALUES (1, 1); INSERT INTO foo (a, b) VALUES (2, 2); INSERT INTO foo (a, b) VALUES (3, 3); -- 触发器定义 DELIMITER /// CREATE TRIGGER ins_sum AFTER UPDATE ON foo FOR EACH ROW BEGIN IF NEW.ts <> OLD.ts THEN INSERT INTO bar (a, b) VALUES (NEW.a, NEW.b); END IF; END; /// DELIMITER ; -- 不更改地更新 UPDATE foo SET b = 3 WHERE a = 3; -- 更改地更新 UPDATE foo SET b = 4 WHERE a = 3;
첫 번째 업데이트를 수행한 후에는(변경 사항 없이) 트리거가 실행되지 않습니다. 그러나 두 번째 업데이트에서는 행이 변경되고 트리거가 실행되어 "막대" 테이블에 새 행이 삽입됩니다.
이 솔루션을 사용하면 개별 열 값을 명시적으로 비교할 필요가 없으며 행이 실제로 변경될 때만 트리거가 실행됩니다.
위 내용은 변경되지 않은 행에서 MySQL 'AFTER UPDATE' 트리거가 실행되는 것을 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사는 MySQL의 Alter Table 문을 사용하여 열 추가/드롭 테이블/열 변경 및 열 데이터 유형 변경을 포함하여 테이블을 수정하는 것에 대해 설명합니다.

기사는 인증서 생성 및 확인을 포함하여 MySQL에 대한 SSL/TLS 암호화 구성에 대해 설명합니다. 주요 문제는 자체 서명 인증서의 보안 영향을 사용하는 것입니다. [문자 수 : 159]

기사는 MySQL에서 파티셔닝, 샤딩, 인덱싱 및 쿼리 최적화를 포함하여 대규모 데이터 세트를 처리하기위한 전략에 대해 설명합니다.

기사는 MySQL Workbench 및 Phpmyadmin과 같은 인기있는 MySQL GUI 도구에 대해 논의하여 초보자 및 고급 사용자를위한 기능과 적합성을 비교합니다. [159 자].

이 기사에서는 Drop Table 문을 사용하여 MySQL에서 테이블을 떨어 뜨리는 것에 대해 설명하여 예방 조치와 위험을 강조합니다. 백업 없이는 행동이 돌이킬 수 없으며 복구 방법 및 잠재적 생산 환경 위험을 상세하게합니다.

이 기사에서는 PostgreSQL, MySQL 및 MongoDB와 같은 다양한 데이터베이스에서 JSON 열에서 인덱스를 작성하여 쿼리 성능을 향상시킵니다. 특정 JSON 경로를 인덱싱하는 구문 및 이점을 설명하고 지원되는 데이터베이스 시스템을 나열합니다.

기사는 외국 열쇠를 사용하여 데이터베이스의 관계를 나타내고 모범 사례, 데이터 무결성 및 피할 수있는 일반적인 함정에 중점을 둡니다.

기사는 준비된 명령문, 입력 검증 및 강력한 암호 정책을 사용하여 SQL 주입 및 무차별 적 공격에 대한 MySQL 보안에 대해 논의합니다 (159 자)


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

Dreamweaver Mac版
시각적 웹 개발 도구
