>데이터 베이스 >MySQL 튜토리얼 >MySQL에서 여러 전역 SQL_MODE 값을 올바르게 설정하는 방법은 무엇입니까?

MySQL에서 여러 전역 SQL_MODE 값을 올바르게 설정하는 방법은 무엇입니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-04 20:09:16282검색

How to Correctly Set Multiple Global SQL_MODE Values in MySQL?

MySQL에서 전역 SQL_MODE 설정: 다양한 모드, 장점 및 선호되는 접근 방식

MySQL에서 전역적으로 SQL_MODE를 설정하려고 하면 사용자에게 다음과 같은 문제가 발생할 수 있습니다. 오류. 이 오류는 다중 모드를 설정하는 올바른 방법, 세션 모드와 전역 모드를 모두 설정하는 이점, 선호하는 접근 방식에 대한 질문을 촉발합니다.

이것이 다중 모드를 설정하는 올바른 방법이 아닙니까?

제공된 명령어 set global sql_mode='NO_BACKSLASH_ESCAPES','STRICT_TRANS_TABLE','NO_AUTO_CREATE_USER','NO_ENGINE_SUBSTITUTION'은 전역적으로 여러 SQL_MODE 값을 설정하기 위한 올바른 구문이 아닙니다. 올바른 접근 방식은 큰따옴표 안에 쉼표를 사용하여 원하는 모드를 결합하는 것입니다.

예:

SET GLOBAL sql_mode='NO_BACKSLASH_ESCAPES,STRICT_TRANS_TABLE,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION';

세션 및 전역 설정의 장점은 무엇입니까? 모드?

  • 세션 모드: 현재 데이터베이스 연결에 적용되며 모든 전역 설정을 재정의합니다. 다른 사용자에게 영향을 주지 않고 SQL_MODE 설정을 임시로 변경할 수 있습니다.
  • 글로벌 모드: 서버의 모든 데이터베이스 연결에 적용됩니다. 모든 사용자에게 일관된 SQL_MODE를 보장합니다.

선호 접근 방식

SQL_MODE 설정에 대한 선호 접근 방식은 특정 요구 사항에 따라 다릅니다.

  • 임시 변경 사항: 세션 모드를 사용하여 설정 특정 사용자 또는 세션에 대한 SQL_MODE 값.
  • 영구 변경: 전역 모드를 사용하여 서버의 모든 사용자에 대해 SQL_MODE 값을 설정합니다. 서버가 다시 시작된 후에도 유지되도록 MySQL 구성 파일(my.cnf)에서 이러한 설정을 구성합니다.

글로벌 SQL_MODE를 영구적으로 설정하는 예

MySQL 구성 파일(/etc/mysql/my.cnf):

[mysqld]
sql-mode="STRICT_TRANS_TABLES,NO_ENGINE_SUBSTITUTION"

위 내용은 MySQL에서 여러 전역 SQL_MODE 값을 올바르게 설정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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