Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 545|回复: 0

MySQL函数不能创建的解决方法

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-4-30 14:25:01 | 显示全部楼层 |阅读模式

    MySQL函数不能创建,是一个很麻烦的问题,下面就为您提供了一个解决此问题的方法,如果您也遇到过类似的问题,不妨一看。

    http://database.51cto.com/art/201010/229918.htm

    在使用MySQL数据库时,有时会遇到MySQL函数不能创建的情况。下面就教您一个解决MySQL函数不能创建问题的方法,供您借鉴参考。

    出错信息大致类似:

    ERROR 1418 (HY000): 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)
    ERROR 1418 (HY000): 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)

    MySQL函数不能创建,是未开启功能:

    1. mysql> show variables like '%func%';  
    2. +---------------------------------+-------+  
    3. | Variable_name                   | Value |  
    4. +---------------------------------+-------+  
    5. | log_bin_trust_function_creators | OFF   |  
    6. +---------------------------------+-------+  
    7. 1 row in set (0.00 sec)  
    8.  
    9. mysql> set global log_bin_trust_function_creators=1;  
    10. Query OK, 0 rows affected (0.00 sec)  
    11.  
    12. mysql> show variables like '%func%';  
    13. +---------------------------------+-------+  
    14. | Variable_name                   | Value |  
    15. +---------------------------------+-------+  
    16. | log_bin_trust_function_creators | ON    |  
    17. +---------------------------------+-------+  
    18. 1 row in set (0.00 sec)mysql

    ==================

     

     

    http://blog.csdn.net/ciwei007/article/details/15635151

     

    1MySQL中创建自定义函数报错信息如下:

    ERROR 1418 (HY000): 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)

     

    解决方法:

    mysql>set global log_bin_trust_function_creators=1;

     

    源文档 <http://blog.csdn.net/zzs0829/article/details/3933326>

     

     

    2创建function时

    出错信息:

    ERROR 1418 (HY000): 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中创建函数时出现这种错误的解决方法:

    set global log_bin_trust_function_creators=TRUE;

     

    源文档 <http://hi.baidu.com/alovn/blog/item/590412157d0c0c04972b43ce.html>

     

    3

    向MySQL导入数据的时候出错

    出错信息:

    ERROR 1418 (HY000): 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指定一个参数。 

    解决方法:

    SQL code

    mysql> show variables like '%func%';

    +---------------------------------+-------+

    | Variable_name                   | Value |

    +---------------------------------+-------+

    | log_bin_trust_function_creators | OFF   |

    +---------------------------------+-------+

    1 row in set (0.00 sec)

     

    mysql> set global log_bin_trust_function_creators=1;

    Query OK, 0 rows affected (0.00 sec)

     

    mysql> show variables like '%func%';

    +---------------------------------+-------+

    | Variable_name                   | Value |

    +---------------------------------+-------+

    | log_bin_trust_function_creators | ON    |

    +---------------------------------+-------+

    1 row in set (0.00 sec)

     

    源文档 <http://miaoyue.iteye.com/blog/1270712>

     

    4

    今天要写一个函数.但没有办法建提示错误如下:

    ERROR 1418 (HY000): 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)

    解决方式:(编缉my.cnf,添加如下)

    [mysqld]

    log_bin_trust_routine_creators = 1

    重启mysql就好了

    humen1 Tech

     

    源文档 <http://www.humen1.net/?p=75>

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-22 22:55 , Processed in 0.113575 second(s), 27 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表