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

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