MySQL 创建函数报错 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

问题描述

通过Navicat客户端,创建MySQL函数(根据的当前节点查询其左右叶子节点)时报错,报错信息如下:

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)

问题原因

这是我们开启了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中创建函数时出现这种错误的解决方法,先执行下面的SQL语句,在执行创建函数的语句即可:

set global log_bin_trust_function_creators=TRUE;

PS:

关于根据节点查询其下所有叶子节点的函数SQL,有兴趣的同学,请参考如下博文:

https://www.cnblogs.com/miracle-luna/p/10828476.html

希望能帮到需要帮助的同行,谢谢。

猜你喜欢

转载自www.cnblogs.com/miracle-luna/p/10856302.html