This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its de 错误解决办法

本文详细解析了在MySQL中创建函数时遇到的特定错误:'This function has none of DETERMINISTIC, NOSQL, or READS SQL DATA in its declaration and binary logging is enabled'。文章首先介绍了四种函数类型:DETERMINISTIC、NOSQL、READSSQLDATA和MODIFIESSQLDATA,并解释了它们的区别。随后,分析了错误产生的原因,并提供了两种解决方案:一是通过设置全局变量log_bin_trust_function_creators为TRUE;二是修改配置文件my.cnf中的log_bin_trust_function_creators参数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值