>데이터 베이스 >MySQL 튜토리얼 >MySQL 테이블에서 빈 문자열 삽입을 방지하려면 어떻게 해야 합니까?

MySQL 테이블에서 빈 문자열 삽입을 방지하려면 어떻게 해야 합니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-19 05:50:02312검색

How Can I Prevent Empty String Inserts in MySQL Tables?

제약조건을 사용하여 MySQL에서 빈 문자열 삽입 방지

앞서 논의에서 MySQL에서 NULL 값 삽입을 방지하는 방법을 제시했습니다. . 그러나 제약 조건에도 불구하고 실수로 빈 문자열이 삽입되는 것이 허용되었습니다. 이 문서에서는 데이터베이스 제약 조건을 사용하여 데이터베이스와 애플리케이션 측면 모두에서 데이터 무결성을 보장하면서 이 문제를 해결하는 방법을 살펴봅니다.

다음 테이블 정의를 고려하세요.

CREATE TABLE IF NOT EXISTS tblFoo (
  foo_id int(11) NOT NULL AUTO_INCREMENT,
  foo_test varchar(50) NOT NULL,
  PRIMARY KEY (foo_id)
);

이 정의는 foo_test 열에 대한 NOT NULL 제약 조건은 여전히 ​​빈 문자열 삽입을 허용합니다.

INSERT INTO tblFoo (foo_test) VALUES ('');

이를 방지하려면 CHECK 제약 조건을 활용할 수 있습니다. 그러나 MySQL 버전 8.0 이전에는 이러한 유형의 제약 조건이 지원되지 않았다는 점에 유의하는 것이 중요합니다. MySQL 참조 매뉴얼에 명시된 대로:

The CHECK clause is parsed but ignored by all storage engines.

이전 MySQL 버전의 경우 해결 방법은 제안된 대로 트리거를 사용하는 것입니다. 그러나 향후 개발에서는 PostgreSQL과 같이 데이터 무결성에 대한 향상된 지원을 갖춘 데이터베이스를 고려하는 것이 유리할 수 있습니다.

위 내용은 MySQL 테이블에서 빈 문자열 삽입을 방지하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.