(转)This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de 错误解决办法

【转载原因:mysql创建函数,报错,参考可以解决】

【转载原文:https://www.cnblogs.com/kiko2014551511/p/11527423.html

1. 创建函数时报错信息

 执行创建函数的sql语句时,提示:This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled

2. 错误分析

我们创建函数时必须指定我们的函数是否是

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


3. 解决方案

在MySQL中创建函数时出现这种错误的解决方法:
1. 在mysql数据库中执行以下语句 (临时生效,重启后失效)
    set global log_bin_trust_function_creators=TRUE;

2. 在配置文件/etc/my.cnf的[mysqld]配置log_bin_trust_function_creators=1

参考地址
https://blog.csdn.net/topasstem8/article/details/8216740

作者:小念
出处:https://www.cnblogs.com/kiko2014551511/
本文版权归作者和博客园共有,欢迎转载,但必须给出原文链接,并保留此段声明,否则保留追究法律责任的权利。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值