> 데이터 베이스 > MySQL 튜토리얼 > MySQL은 CHECK 제약 조건을 지원합니까? 그렇지 않은 경우 대안은 무엇입니까?

MySQL은 CHECK 제약 조건을 지원합니까? 그렇지 않은 경우 대안은 무엇입니까?

Susan Sarandon
풀어 주다: 2025-01-01 14:31:11
원래의
639명이 탐색했습니다.

Does MySQL Support CHECK Constraints, and If Not, What Are the Alternatives?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿