MySQL创建函数错误 ER_BINLOG_UNSAFE_ROUTINE; SQLSTATE: HY000

今天创建函数时候遇到一个问题,如下所示:
sql:

DROP FUNCTION IF EXISTS xxxxxxx;
DELIMITER $
CREATE FUNCTION xxxxxxx (seq_name VARCHAR(50))     
RETURNS INTEGER
CONTAINS SQL     
BEGIN     
  DECLARE value INTEGER;     
  SET value = 0;     
  SELECT current_value INTO value     
  FROM xxx
  WHERE name = seq_name;
  RETURN value;     
END$
DELIMITER ;

This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary log
因为是在本地创建的,我本地数据库是MySQL8.0版本的。所以我想当然觉得是版本问题,我还在测试上试了下(MySQL5.7),结果能运行。我第一反应觉得是高版本创建语法可能严格点儿,所以我依照官方文档:
CREATE PROCEDURE and CREATE FUNCTION Syntax
修改了语法,如下:

DROP FUNCTION IF EXISTS xxxxxxx;
DELIMITER $
CREATE FUNCTION xxxxxxx (seq_name VARCHAR(50))     
RETURNS INTEGER
COMMENT '下一个值'
MODIFIES SQL DATA
CONTAINS SQL     
BEGIN     
  DECLARE value INTEGER;     
  SET value = 0;     
  SELECT current_value INTO value     
  FROM xxx
  WHERE name = seq_name;
  RETURN value;     
END$
DELIMITER ;

结果还是不行。
最后还是借助搜索引擎解决的,解决办法如下:
原文在此

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) 

是自定义函数功能未开启所致。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值