"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > MySQL에서 \"1418(HY000) 이 함수의 선언에 DETERMINISTIC, NO SQL 또는 READS SQL DATA가 없고 바이너리 로깅이 활성화되어 있습니다\" 오류를 해결하는 방법은 무엇입니까?

MySQL에서 \"1418(HY000) 이 함수의 선언에 DETERMINISTIC, NO SQL 또는 READS SQL DATA가 없고 바이너리 로깅이 활성화되어 있습니다\" 오류를 해결하는 방법은 무엇입니까?

2024년 11월 16일에 게시됨
검색:337

How to Solve the \

MySQL 데이터베이스를 가져올 때 10185행에서 "1418(HY000) 오류가 발생할 수 있습니다. 이 함수의 선언에는 DETERMINISTIC, NO SQL 또는 READS SQL DATA가 없습니다. 바이너리 로깅이 활성화되었습니다(덜 안전한 log_bin_trust_function_creators 변수를 사용하고 싶을 수도 있습니다." 이 오류는 데이터베이스 내에서 함수의 결정적 특성을 지정하지 않았을 때 발생합니다.

이 오류를 해결하려면 다음 두 가지 방법 중 하나를 사용할 수 있습니다.

방법 1: 일시적으로 바이너리 로깅 비활성화

SET GLOBAL log_bin_trust_function_creators = 1;

방법 2: mysql.ini 파일 구성

log_bin_trust_function_creators = 1;

이 값을 1로 설정하면 비결정적 기능에 대한 검사가 완화됩니다. 이 옵션은 잠재적으로 데이터 무결성을 손상시킬 수 있으므로 주의해서 사용해야 합니다.

결정적 함수 이해

향후 이 오류를 방지하려면 더 나은 접근 방식이 필요합니다. 저장된 함수에 대해 결정론적 선언을 사용하는 것입니다. 이러한 선언은 함수가 동일한 입력 매개변수에 대해 항상 동일한 결과를 생성하는지 여부를 MySQL에 알려줍니다. 다음은 다양한 결정론적 선언입니다.

DETERMINISTIC:

  • 동일한 입력 매개변수에 대해 항상 동일한 결과를 생성하는 함수.

NOT DETERMINISTIC:

  • 동일한 입력 매개변수에 대해 항상 동일한 결과를 생성하지 않는 함수입니다. 명시적으로 선언하지 않으면 MySQL의 기본값은 NOT DETERMINISTIC입니다.

READS SQL DATA:

  • 데이터베이스에서 데이터만 읽는 함수.

NO SQL:

  • SQL 문을 포함하지 않는 함수.

CONTAINS SQL:

  • SQL 명령을 포함하지만 데이터를 읽거나 쓰지 않는 함수.

올바른 선언 선택

올바른 선언 선택 함수 선언은 해당 동작에 따라 달라집니다. 함수의 출력이 현재 시간이나 난수 생성기와 같은 데이터베이스 외부 요인에 따라 달라지는 경우 NOT DETERMINISTIC으로 선언해야 합니다. 함수가 데이터만 읽는 경우 READS SQL DATA로 선언할 수 있습니다. 함수에 SQL 문이 포함되어 있지 않으면 NO SQL로 선언할 수 있습니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3