MySQL에 사용자 정의 CHECK 제약 조건 추가
MySQL 문서에는 CHECK 제약 조건의 예가 포함되어 있지만 이러한 제약 조건은 현재 엔진에서 지원됩니다. 결과적으로 테이블 정의에서 이를 정의해도 데이터 값에 대한 제한이 적용되지 않습니다.
설명
MySQL 매뉴얼에 따르면 "CHECK 절은 구문 분석됩니다. 하지만 모든 스토리지 엔진에서는 무시됩니다." 즉, MySQL은 CHECK 제약 조건 정의를 테이블에 적용하지 않고 단순히 건너뜁니다.
해결 방법
안타깝게도 MySQL은 CHECK를 시행하는 직접적인 방법을 제공하지 않습니다. 제약. 그러나 한 가지 가능한 해결 방법은 대신 트리거를 만드는 것입니다. 트리거는 테이블에 대한 INSERT, UPDATE 또는 DELETE 작업과 같은 특정 이벤트에 응답하는 데이터베이스 개체입니다.
예를 들어 INSERT 또는 DELETE 작업을 허용하기 전에 상태 속성 값을 확인하는 트리거를 생성할 수 있습니다. UPDATE 작업이 발생합니다. 다음은 이러한 트리거에 대한 샘플 코드 조각입니다.
DELIMITER $$ CREATE TRIGGER participants_validate_status BEFORE INSERT OR UPDATE ON Participants FOR EACH ROW BEGIN IF NEW.status NOT IN ('a', 'd', 'u') THEN SIGNAL SQLSTATE '45000' SET MESSAGE_TEXT = 'Invalid value for status'; END IF; END $$ DELIMITER ;
대체 솔루션
CHECK 제약 조건을 지원하는 데이터베이스가 필요한 경우 대체 오픈 소스 사용을 고려하세요. PostgreSQL과 같은 RDBMS. PostgreSQL은 CHECK 제약 조건에 대한 강력한 지원을 제공하며 데이터 무결성 관리를 위한 실행 가능한 옵션입니다.
위 내용은 MySQL은 CHECK 제약 조건을 지원합니까? 그렇지 않은 경우 대안은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!