MENU

This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de

September 24, 2019 • Read: 2504 • mysql问题

今天往116上迁移数据库,报错

1418- This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log bin trust function creators variable

翻译:

这个函数没有确定性,没有SQL,或者在声明中读取SQL数据,并且启用了二进制日志记录(您*可能*想要使用不太安全的log bin trust函数creator变量)

这是我们开启了bin-log, 我们就必须指定我们的函数是否是

1 DETERMINISTIC 不确定的
2 NO SQL 没有SQl语句,当然也不会修改数据
3 READS SQL DATA 只是读取数据,当然也不会修改数据
4 MODIFIES SQL DATA 要修改数据
5 CONTAINS SQL 包含了SQL语句

其中在function里面,只有 DETERMINISTIC, NO SQL 和 READS SQL DATA 被支持。如果我们开启了 bin-log, 我们就必须为我们的function指定一个参数。

在MySQL中创建函数时出现这种错误的解决方法:

set global log_bin_trust_function_creators=TRUE;

兼总条贯 知至知终