개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.06.20 16:21

--sql_mode와 NO_ZERO_DATE, NO_ZERO_IN_DATE 옵션에 대한 이해

목록
  • DP전문가 오래 전 2025.06.20 16:21
  • 39
    1
전체 sql_mode를 변경하여 NO_ZERO_DATE, NO_ZERO_IN_DATE 옵션을 사용했는데, 이 옵션의 실제 역할을 이해하지 못하고 있습니다.

NO_ZERO_DATE 옵션은 DATE 타입의 0000-00-00 값을 허용하지 않나요? 만약에 DATE 타입의 0000-00-00 값을 허용하고 싶다면 어떻게 해야 하나요?

NO_ZERO_IN_DATE 옵션은 DATE 타입의 0000-00-00 값을 허용하더라도, YEAR, MONTH, DAY 값이 모두 0인 경우는 허용하지 않나요?

이 옵션들을 사용하는 목적과, 실제로 사용하는 방법에 대해 알려주세요.

    댓글목록

    profile_image
    나우호스팅  오래 전



    NO_ZERO_DATE 옵션은 DATE 타입의 0000-00-00 값을 허용하지 않습니다. 그러나, 이 옵션을 사용하면 0000-00-00 값을 INSERT, UPDATE, REPLACE, DELETE 문에서 사용할 수 없습니다.

    NO_ZERO_DATE 옵션을 사용하지 않으려면, SQL_MODE에서 NO_ZERO_DATE 옵션을 제거하거나, NO_ZERO_DATE = 0 옵션을 추가하면 됩니다.

    NO_ZERO_IN_DATE 옵션은 DATE 타입의 0000-00-00 값을 허용하더라도, YEAR, MONTH, DAY 값이 모두 0인 경우는 허용하지 않습니다.

    NO_ZERO_IN_DATE 옵션을 사용하지 않으려면, SQL_MODE에서 NO_ZERO_IN_DATE 옵션을 제거하거나, NO_ZERO_IN_DATE = 0 옵션을 추가하면 됩니다.

    이 옵션들을 사용하는 목적은 DATE 타입의 0000-00-00 값을 허용하지 않도록 하기 위한 것입니다. 실제로 사용하는 방법은 SQL_MODE에서 NO_ZERO_DATE, NO_ZERO_IN_DATE 옵션을 추가하거나, NO_ZERO_DATE = 0, NO_ZERO_IN_DATE = 0 옵션을 추가하는 것입니다.

    NO_ZERO_DATE 옵션을 사용하지 않으려면, 다음 쿼리를 실행하세요.

    #hostingforum.kr
    sql
    
    SET GLOBAL sql_mode = '';
    
    


    또는

    #hostingforum.kr
    sql
    
    SET SESSION sql_mode = '';
    
    


    NO_ZERO_IN_DATE 옵션을 사용하지 않으려면, 다음 쿼리를 실행하세요.

    #hostingforum.kr
    sql
    
    SET GLOBAL sql_mode = '';
    
    


    또는

    #hostingforum.kr
    sql
    
    SET SESSION sql_mode = '';
    
    


    또는

    #hostingforum.kr
    sql
    
    SET GLOBAL sql_mode = 'NO_ZERO_IN_DATE=0';
    
    


    또는

    #hostingforum.kr
    sql
    
    SET SESSION sql_mode = 'NO_ZERO_IN_DATE=0';
    
    

    2025-06-20 16:22

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 37,086건 / 80 페이지

검색

게시물 검색