MySQL 错误1418

创建function的时候报如下错误:

Error Code : 1418
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)
(0 ms taken)

解决方法如下:

1. mysql> set global log_bin_trust_function_creators = 1;
2. 系统启动时 --log-bin-trust-function-creators=1
3. 配置文件my.conf中 [mysqld] 标记后加一行内容为 log-bin-trust-function-creators=1

 

参数og_bin_trust_function_creators的使用说明

开启二进制日志后,log_bin_trust_function_creators参数才会生效。
该参数控制是否信任允许用户创建的、可能会导致不安全事件被写入二进制日志的functions和triggers。
如果log_bin_trust_function_creators=0(默认值),用户不允许创建或者修改functions;要想创建或修改functionss,除了create routine或alter routine权限,还要有super权限。设置为0时,还要求创建创建的function必须带有deterministic,或者reads sql data、no sql属性。
如果log_bin_trust_function_creators=1,mysql不会对创建functions施加上面的限制。
log_bin_trust_function_creators对trigger具有相似的限制原理。

  

想更多研究,可以看看网友的文章:

http://blog.sina.com.cn/s/blog_6f68845001013k8a.html

因为create procedure, create function, alter procedure,alter function,call, drop procedure, drop function等语句都会被写进二进制日志,然后在从服务器上执行。但是,一个执行更新的不确定子程序(存储过程、函数、触发器)是不可重复的,在从服务器上执行(相对与主服务器是重复执行)可能会造成恢复的数据与原始数据不同,从服务器不同于主服务器的情况。

为了解决这个问题,mysql强制要求:
在主服务器上,除非子程序被声明为确定性的或者不更改数据,否则创建或者替换子程序将被拒绝。这意味着当创建一个子程序的时候,必须要么声明它是确定性的,要么它不改变数据。

声明方式有两种:
第一种:声明是否是确定性的
deterministic和not deterministic指出一个子程序是否对给定的输入总是产生同样的结果。
如果没有给定任一特征,默认是not deterministic,所以必须明确指定deterministic来声明一个子程序是确定性的。
这里要说明的是:使用now() 函数(或它的同义)或者rand() 函数不会使一个子程序变成非确定性的。对now()而言,二进制日志包括时间戳并会被正确的执行。rand()只要在一个子程序内被调用一次也可以被正确的复制。所以,可以认为时间戳和随机数种子是子程序的确定性输入,它们在主服务器和从服务器上是一样的。

第二种:声明是否会改变数据
contains sql, no sql, reads sql data, modifies sql用来指出子程序是读还是写数据的。
无论no sql还是reads sql data都指出,子程序没有改变数据,但是必须明确地指定其中一个,因为如果任何指定,默认的指定是contains sql。
默认情况下,如果允许create procedure 或create function 语句被接受,就必须明确地指定deterministic 或 no sql与reads sql data 中的一个,否则就会产生1418错误。

解决方法:

解决办法也有两种,
第一种是在创建子程序(存储过程、函数、触发器)时,声明为deterministic或no sql与reads sql data中的一个,
例如:
create definer = current_user procedure `newproc`()
deterministic
begin
#routine body goes here...
end;

第二种是信任子程序的创建者,禁止创建、修改子程序时对super权限的要求,设置log_bin_trust_routine_creators全局系统变量为1。设置方法有三种:

1.在客户端上执行set global log_bin_trust_function_creators = 1;
2.mysql启动时,加上--log-bin-trust-function-creators选贤,参数设置为1
3.在mysql配置文件my.ini或my.cnf中的[mysqld]段上加log-bin-trust-function-creators=1

时间: 2024-10-05 10:08:23

MySQL 错误1418的相关文章

MYSQL 错误 :Out of resources when opening file './datagather/mx_domain#P#p178.MYD' (Errcode: 24) 解决办法

出现Out of resources when opening file './xxx.MYD' (Errcode: 24)错误是因为打开的文件数超过了my.cnf的--open-files-limit. open-files-limit选项无法在mysql命令行 直接修改,必须在my.cnf中设定,最大值是65536. 重新启动mysqld, mysql> show variables like 'open%'; +------------------+-------+ | Variable_

MySQL 错误日志(Error Log)

同大多数关系型数据库一样,日志文件是MySQL数据库的重要组成部分.MySQL有几种不同的日志文件,通常包括错误日志文件,二进制日志,通用日志,慢查询日志,等等.这些日志可以帮助我们定义mysqld内部发生的事情,数据库性能故障,记录数据的变更历史,用户恢复数据库等等.本文主要描述错误日志文件. 1.MySQL日志文件系统的组成   a.错误日志:记录启动.运行或停止mysqld时出现的问题.   b.通用日志:记录建立的客户端连接和执行的语句.   c.更新日志:记录更改数据的语句.该日志在M

解决远程连接mysql错误1130

Mysql远程连接Mysql服务器的数据库,错误代码是1130,ERROR 1130: Host xxx.xxx.xxx.xxx  is not allowed to connect to this MySQL server  猜想是无法给远程连接的用户权限问题. 这样子操作mysql库,即可解决.  在本机登入mysql后,更改 "mysql" 数据库里的 "user" 表里的 "host" 项,从"localhost"改称

mysql错误:The MySQL server is running with the --skip-grant-tables option so it cannot execute this statement解决方法

Mysql关系型数据库管理系统 MySQL是一个开放源码的小型关联式数据库管理系统,开发者为瑞典MySQL AB公司.MySQL被广泛地应用在Internet上的中小型网站中.由于其体积小.速度快.总体拥有成本低,尤其是开放源码这一特点,许多中小型网站为了降低网站总体拥有成本而选择了MySQL作为网站数据库. 本文为大家讲解的是mysql错误:The MySQL server is running with the --skip-grant-tables option so it cannot

关于MySQL错误 2005 - Unknown MySQL server host 'localhost' (0) 原因及解决方法

今天在外面开navicat for mysql的时候,怎么也连不上自己本机上的数据库,一直显示2005 - Unknown MySQL server host 'localhost' (0): 错误代码的意思即无法连接上主机localhost.可能是由于没有联网造成的:于是将连接属性里的 '主机名或IP地址' 改成127.0.0.1即回送地址后,就可以连接上了.上百度搜了下,navicat里的一些功能应该是要联网的,而localhost是需要DNS解析后才会是127.0.0.1的,所以才会导致这

MySQL错误日志总结

MySQL错误日志是记录MySQL 运行过程中较为严重的警告和错误信息,以及MySQL每次启动和关闭的详细信息.错误日志的命名通常为hostname.err.其中,hostname表示服务器主机名. The error log contains information indicating when mysqld was started and stopped and also any critical errors that occur while the server is running.

MySQL错误2003:Can't connect to MySQL server (10060)

1.网络不通. 检查能不能ping通. 2.防火墙设置. 防火墙是否放过mysql的进程,是否屏蔽了mysql的3306端口. 3.mysql的账户设置. mysql账户是否不允许远程连接.如果无法连接可以尝试以下方法: 也可以通过修改表来实现远程: <转> MySQL错误2003:Can't connect to MySQL server (10060)

MYSQL错误Can&#39;t connect to local MySQL server through socket &#39;/var/lib/mysql/mysq

1.创建/修改文件 /etc/my.cnf,至少增加/修改一行 [mysql] [client] socket = /tmp/mysql.sock #在这里写上你的mysql.sock的正确位置,通常不是在 /tmp/ 下就是在 /var/lib/mysql/ 下2.指定IP地址,使用tcp方式连接mysql,而不使用本地sock方式 #mysql -h127.0.0.1 -uuser -ppassword 3.为 mysql.sock 加个连接,比如说实际的mysql.sock在 /tmp/

ERROR 2002 (HY000): Can&#39;t connect to local MySQL server through socket &#39;/var/lib/mysql/mysql.sock&#39; (2)--MySQL错误

环境:RHEL5.5 centos的yum源更新 1.启动MySQL出现错误: ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2) 2.解决方法(摘自:http://wenda.haosou.com/q/1364099334067193?src=150) 1.先查看 /etc/rc.d/init.d/mysqld status 看看m y s