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:
결정적이지 않음:
SQL 데이터 읽기:
NO SQL:
CONTAINS SQL:
올바른 선언 선택
올바른 선언 선택 함수 선언은 해당 동작에 따라 달라집니다. 함수의 출력이 현재 시간이나 난수 생성기와 같은 데이터베이스 외부 요인에 따라 달라지는 경우 NOT DETERMINISTIC으로 선언해야 합니다. 함수가 데이터만 읽는 경우 READS SQL DATA로 선언할 수 있습니다. 함수에 SQL 문이 포함되어 있지 않으면 NO SQL로 선언할 수 있습니다.
위 내용은 MySQL에서 \"1418(HY000) 이 함수의 선언에 DETERMINISTIC, NO SQL 또는 READS SQL DATA가 없고 바이너리 로깅이 활성화되어 있습니다\" 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!