DoubleLi

qq: 517712484 wx: ldbgliet

  博客园 :: 首页 :: 博问 :: 闪存 :: 新随笔 :: 联系 :: 订阅 订阅 :: 管理 ::
  4737 随笔 :: 2 文章 :: 541 评论 :: 1612万 阅读

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

posted on   DoubleLi  阅读(3396)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示