>데이터 베이스 >MySQL 튜토리얼 >MySQL이 항상 CURRENT_DATE/CURDATE()를 기본값으로 허용하지 않는 이유는 무엇입니까?

MySQL이 항상 CURRENT_DATE/CURDATE()를 기본값으로 허용하지 않는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-07 11:49:12804검색

Why Doesn't MySQL Always Accept CURRENT_DATE/CURDATE() as a Default Value?

MySQL의 CURRENT_DATE/CURDATE() 기본값 문제

개발자가 직면하는 일반적인 딜레마 중 하나는 CURRENT_DATE 또는 CURDATE() 함수를 다음과 같이 사용하는 것과 관련됩니다. MySQL의 DATE 열에 대한 기본값입니다. 기대에도 불구하고 이러한 기능은 의도한 대로 작동하지 않습니다.

이유는 MySQL의 기본값 제한에 있습니다. 일반적으로 기본값은 함수나 표현식이 아닌 상수여야 합니다. 따라서 DATE 열의 기본값을 NOW() 또는 CURRENT_DATE로 설정하면 실패합니다.

CREATE TABLE INVOICE(
   INVOICEDATE DATE NOT NULL DEFAULT CURRENT_DATE
)

[편집: 기본값으로 CURRENT_DATE/CURDATE() 지원]

MySQL 버전 8.0.13에서 CURRENT_DATE에 대한 지원을 도입했다는 점은 주목할 가치가 있습니다. 및 CURDATE()를 DATE 열의 기본값으로 사용합니다. 그러나 이전 버전에서는 이 기능을 지원하지 않습니다.

TIMESTAMP 열에 대한 예외

규칙의 주목할만한 예외는 CURRENT_TIMESTAMP를 TIMESTAMP의 기본값으로 사용할 수 있다는 것입니다. MySQL에서 지원하는 열입니다. 이 측면에 대한 자세한 내용은 MySQL 설명서를 참조하세요.

위 내용은 MySQL이 항상 CURRENT_DATE/CURDATE()를 기본값으로 허용하지 않는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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