导读:本期聚焦于小伙伴创作的《mysql自定义函数为什么报1418错误 如何设置log_bin_trust_function_creators》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《mysql自定义函数为什么报1418错误 如何设置log_bin_trust_function_creators》有用,将其分享出去将是对创作者最好的鼓励。

在mysql数据库的使用过程中,很多开发者在创建自定义函数时会遇到1418错误,该错误的完整提示通常为“This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled”。这个错误的出现和mysql的二进制日志机制以及函数安全性校验规则直接相关。

mysql自定义函数为什么报1418错误 如何设置log_bin_trust_function_creators

1418错误的产生原因

当mysql开启了二进制日志(binlog)功能时,为了保证主从复制场景下数据的一致性,会对自定义函数的创建做严格限制。如果自定义函数被标记为不确定或者会修改数据,那么在主库执行后同步到从库时,可能会出现主从数据不一致的问题。

mysql要求开启binlog时创建的自定义函数必须满足以下条件之一:

  • 函数声明中包含DETERMINISTIC关键字,表示函数是确定性的,相同输入必然得到相同输出
  • 函数声明中包含NO SQL关键字,表示函数不包含SQL语句
  • 函数声明中包含READS SQL DATA关键字,表示函数仅读取数据不修改数据
  • 开启log_bin_trust_function_creators参数,信任函数创建者,跳过上述校验

如果创建函数时既没有满足上述前三个条件,也没有开启log_bin_trust_function_creators参数,就会触发1418错误。

log_bin_trust_function_creators参数的作用

log_bin_trust_function_creators是mysql的一个系统变量,默认值为OFF。当该参数开启为ON时,mysql会信任函数创建者的操作,不再强制要求自定义函数满足上述三个声明条件,也不会阻止不确定或者包含数据修改逻辑的函数创建。

该参数适合在以下场景使用:

  • 确认自定义函数的逻辑是安全的,不会引发主从数据不一致问题
  • 开发测试环境,不需要严格的主从一致性校验
  • 函数逻辑复杂,无法简单通过DETERMINISTIC等关键字标识

设置log_bin_trust_function_creators的方法

临时设置(当前会话生效)

如果只是临时需要创建自定义函数,可以通过set命令临时开启该参数,重启mysql后会恢复默认值。

-- 查看当前参数值
SHOW VARIABLES LIKE 'log_bin_trust_function_creators';

-- 临时开启参数
SET GLOBAL log_bin_trust_function_creators = 1;

-- 再次查看参数值确认开启
SHOW VARIABLES LIKE 'log_bin_trust_function_creators';

永久设置(重启后生效)

如果需要永久生效,需要修改mysql的配置文件,通常是my.cnf或者my.ini,在[mysqld]配置段下添加参数配置。

[mysqld]
# 开启信任函数创建者参数
log_bin_trust_function_creators = 1

修改完成后重启mysql服务即可生效,不同系统的重启命令如下:

# Linux系统重启mysql
systemctl restart mysqld

# Windows系统重启mysql(服务名为mysql)
net stop mysql
net start mysql

创建自定义函数示例

开启log_bin_trust_function_creators参数后,就可以正常创建自定义函数了,以下是一个简单的求和函数示例。

-- 切换到测试数据库
USE test_db;

-- 创建自定义求和函数
DELIMITER //
CREATE FUNCTION sum_num(a INT, b INT)
RETURNS INT
BEGIN
    DECLARE result INT;
    SET result = a + b;
    RETURN result;
END //
DELIMITER ;

-- 调用函数测试
SELECT sum_num(2, 3);

如果不需要开启log_bin_trust_function_creators参数,也可以在创建函数时添加对应声明,示例如下:

-- 添加DETERMINISTIC声明创建函数
DELIMITER //
CREATE FUNCTION sum_num_safe(a INT, b INT)
RETURNS INT
DETERMINISTIC
BEGIN
    DECLARE result INT;
    SET result = a + b;
    RETURN result;
END //
DELIMITER ;

注意事项

生产环境开启log_bin_trust_function_creators参数时需要谨慎评估,如果函数包含不确定的逻辑或者修改数据的操作,可能会导致主从复制出现数据不一致的问题。如果对函数安全性没有把握,建议优先通过添加DETERMINISTIC、NO SQL、READS SQL DATA声明的方式创建函数,而不是直接开启该参数。

mysql自定义函数log_bin_trust_function_creators1418错误修改时间:2026-06-14 12:24:18

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。