필드를 자동 생성 ID 값으로 기본 설정하는 MySQL 트리거
MySQL에서는 특정 작업을 수행하는 트리거를 생성할 수 있습니다. 수정이 발생하기 전이나 후에 테이블 데이터에 대한 작업이 수행됩니다. 일반적인 사용 사례 중 하나는 필드가 삽입 시 null로 남아 있는 상황에서 자동 생성된 기본 키(ID) 값을 기본값으로 설정하는 것입니다.
문제 설명:
이를 달성하기 위해 id(기본 키), group_id(정수), value(varchar)라는 세 개의 열이 있는 테이블을 생각해 보겠습니다. 레코드 삽입 시 다음 동작을 수행하는 것이 목표입니다.
트리거 구현:
단일 문이나 트리거 내에서 이 작업을 수행하는 것이 바람직하지만 MySQL 제한 사항으로 인해 이를 수행할 수 없습니다. 한 가지 해결 방법은 2단계 접근 방식을 활용하는 것입니다.
CREATE TRIGGER MyTrigger BEFORE INSERT ON MyTable FOR EACH ROW BEGIN SET NEW.group_id = COALESCE(NEW.group_id, NEW.id); END
INSERT INTO MyTable (group_id, value) VALUES (NULL, 'a'); UPDATE MyTable SET group_id = COALESCE(group_id, id) WHERE id = LAST_INSERT_ID();
제한 사항:
BEFORE INSERT 트리거는 새로 생성된 ID 값에 아직 액세스할 수 없으므로 액세스할 수 없다는 점에 유의하는 것이 중요합니다. 할당되었습니다. 그러나 해당 단계에서는 열 값을 수정할 수 없으므로 AFTER INSERT 트리거를 사용하여 생성된 값에 액세스하는 것은 옵션이 아닙니다.
따라서 위에 제시된 2단계 접근 방식은 MySQL에서 원하는 동작에 대한 솔루션을 제공합니다. .
위 내용은 트리거를 사용하여 MySQL에서 자동 생성된 ID로 필드를 기본값으로 설정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!