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

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

Linda Hamilton
Linda Hamilton원래의
2024-11-01 10:44:30994검색

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:

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

결정적이지 않음:

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

SQL 데이터 읽기:

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

NO SQL:

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

CONTAINS SQL:

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

올바른 선언 선택

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

위 내용은 MySQL에서 \"1418(HY000) 이 함수의 선언에 DETERMINISTIC, NO SQL 또는 READS SQL DATA가 없고 바이너리 로깅이 활성화되어 있습니다\" 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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