返回顶部
首页 > 资讯 > 数据库 >MySQL3次导入报错解决!
  • 153
分享到

MySQL3次导入报错解决!

报错 2023-01-31 06:01:46 153人浏览 八月长安
摘要

报错1、ERROR at line 16779: Unknown command '\''.[root@xxxx ~]# Mysql -u hyxd -p xxxx <xxxx.sql Enter passWord: ERROR at

报错1、ERROR at line 16779: Unknown command '\''.

[root@xxxx ~]# Mysql -u hyxd -p xxxx <xxxx.sql 
Enter passWord
ERROR at line 16779: Unknown command '\''.

报错原因:字符集问题

解决方式:修改字符集为utf-8


报错2、ERROR 2006 (HY000) at line 11903: MySQL server has gone away

[root@xxxx ~]# mysql -uhyxd -p xedk <xxxx.sql 
Enter password: 
ERROR 2006 (HY000) at line 11903: MySQL server has Gone away

报错原因:

响应超时等

解决方式:

max_allowed_packet = x M

wait_timeout=10

除此之外,可能还有一些别的buffer_size的变量会影响到,也值得注意!

例如 

read_buffer_size 

read_rnd_buffer_size


报错3、ERROR 1418 (HY000) at line 24166: 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)

root@xxxx ~]# mysql -uroot -p xxxx <xxxx.sql 
Enter password: 
ERROR 1418 (HY000) at line 24166: 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)

报错原因:

MySQL开启bin-log后,调用存储过程或者函数以及触发器时,会出现错误号为1418的错误:

解决方式:

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


第3种报错详细分析:(参考自网络

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


为了解决这个问题,MySQL强制要求:

在主服务器上,除非子程序被声明为确定性的或者不更改数据,否则创建或者替换子程序将被拒绝。

这意味着当创建一个子程序的时候,必须要么声明它是确定性的,要么它不改变数据。


声明方式有两种,

第一种:声明是否是确定性的

DETERMINISTIC和NOT DETERMINISTIC指出一个子程序是否对给定的输入总是产生同样的结果。

如果没有给定任一特征,默认是NOT DETERMINISTIC,所以必须明确指定DETERMINISTIC来声明一个子程序是确定性的。 

这里要说明的是:使用NOW() 函数(或它的同义)或者RAND() 函数不会使一个子程序变成非确定性的。对NOW()而言,二进制日志包括时间戳并会被正确的执行。RAND()只要在一个子程序内被调用一次也可以被正确的复制。所以,www.linuxidc.com可以认为时间戳和随机数种子是子程序的确定性输入,它们在主服务器和从服务器上是一样的。


第二种:声明是否会改变数据  

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错误。


或者理解:

这是我们开启了bin-log, 我们就必须指定我们的函数是否是

1 DETERMINISTIC 不确定的

2 NO SQL 没有SQl语句,当然也不会修改数据

3 READS SQL DATA 只是读取数据,当然也不会修改数据

4 MODIFIES SQL DATA 要修改数据

5 CONTAINS SQL 包含了SQL语句


解决方法:

1、是在创建子程序(存储过程、函数、触发器)时,声明为DETERMINISTIC或NO SQL与READS SQL DATA中的一个,

例如:

CREATE DEFINER = CURRENT_USER PROCEDURE `NewProc`()

    DETERMINISTIC

BEGIN

 #Routine body goes here...

END;;

2、第二种是信任子程序的创建者,禁止创建、修改子程序时对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


常见MySQL报错情况(参考自老男孩)

MySQL常见错误代码及代码说明!

原文:Http://oldboy.blog.51cto.com/2561410/1728380

1005:创建表失败

1006:创建数据库失败

1007:数据库已存在,创建数据库失败<=================可以忽略

1008:数据库不存在,删除数据库失败<=================可以忽略

1009:不能删除数据库文件导致删除数据库失败

1010:不能删除数据目录导致删除数据库失败

1011:删除数据库文件失败

1012:不能读取系统表中的记录

1020:记录已被其他用户修改

1021:硬盘剩余空间不足,请加大硬盘可用空间

1022:关键字重复,更改记录失败

1023:关闭时发生错误

1024:读文件错误

1025:更改名字时发生错误

1026:写文件错误

1032:记录不存在<=============================可以忽略

1036:数据表是只读的,不能对它进行修改

1037:系统内存不足,请重启数据库或重启服务器

1038:用于排序的内存不足,请增大排序缓冲区

1040:已到达数据库的最大连接数,请加大数据库可用连接数

1041:系统内存不足

1042:无效的主机名

1043:无效连接

1044:当前用户没有访问数据库的权限

1045:不能连接数据库,用户名或密码错误

1048:字段不能为空

1049:数据库不存在

1050:数据表已存在

1051:数据表不存在

1054:字段不存在

1062:字段值重复,入库失败<==========================可以忽略

1065:无效的SQL语句,SQL语句为空

1081:不能建立Socket连接

1114:数据表已满,不能容纳任何记录

1116:打开的数据表太多

1129:数据库出现异常,请重启数据库

1130:连接数据库失败,没有连接数据库的权限

1133:数据库用户不存在

1141:当前用户无权访问数据库

1142:当前用户无权访问数据表

1143:当前用户无权访问数据表中的字段

1146:数据表不存在

1147:未定义用户对数据表的访问权限

1149:SQL语句语法错误

1158:网络错误,出现读错误,请检查网络连接状况

1159:网络错误,读超时,请检查网络连接状况

1160:网络错误,出现写错误,请检查网络连接状况

1161:网络错误,写超时,请检查网络连接状况

1169:字段值重复,更新记录失败

1177:打开数据表失败

1180:提交事务失败

1181:回滚事务失败

1203:当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库

1205:加超时

1211:当前用户没有创建用户的权限

1216:外键约束检查失败,更新子表记录失败

1217:外键约束检查失败,删除或修改主表记录失败

1226:当前用户使用的资源已超过所允许的资源,请重启数据库或重启服务器

1227:权限不足,您无权进行此操作

1235:MySQL版本过低,不具有本功能



您可能感兴趣的文档:

--结束END--

本文标题: MySQL3次导入报错解决!

本文链接: https://lsjlt.com/news/189732.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MySQL3次导入报错解决!
    报错1、ERROR at line 16779: Unknown command '\''.[root@xxxx ~]# mysql -u hyxd -p xxxx <xxxx.sql Enter password: ERROR at...
    99+
    2023-01-31
    报错
  • python导入selenium报错怎么解决
    在导入selenium时,可能会遇到各种不同的错误。以下是一些常见的报错和解决方法:1. ImportError: No modul...
    99+
    2023-10-25
    python selenium
  • navicat导入sql报错的解决方法
    小编给大家分享一下navicat导入sql报错的解决方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!场景:100多M的sql文...
    99+
    2024-04-02
  • eclipse导入jar包报错如何解决
    在Eclipse导入jar包时遇到报错,可以尝试以下解决方法:1. 确保jar包文件存在:首先检查导入的jar包文件是否存在,并确保...
    99+
    2023-09-27
    eclipse jar
  • eclipse导入包import报错如何解决
    当在Eclipse中导入包时出现错误,有几种可能的解决方法:1. 检查包路径是否正确:确认包的路径是否与导入语句中的路径一致。确保包...
    99+
    2023-09-27
    eclipse
  • 导入pygame模块报错如何解决
    首先,需要检查是否已经安装了pygame模块。可以在命令行中输入`pip show pygame`来检查是否已经安装了。如果没有安装...
    99+
    2023-09-08
    pygame
  • python导入numpy库报错怎么解决
    导入numpy库报错可能有多种原因,以下是一些常见的解决方法: 确保已经正确安装了numpy库。可以使用pip install ...
    99+
    2023-10-21
    python numpy
  • eclipse导入javaweb项目报错如何解决
    导入javaweb项目时出现报错,有以下几种解决方法:1. 检查项目依赖:确保项目中所需的jar包已正确导入,并在构建路径中设置正确...
    99+
    2023-09-15
    eclipse javaweb
  • eclipse导入项目jsp报错如何解决
    当使用Eclipse导入JSP项目时,可能会遇到一些错误。以下是一些常见的错误和解决方法:1. 缺少JSP容器:如果你的项目中没有J...
    99+
    2023-09-22
    eclipse
  • eclipse导入maven工程报错如何解决
    导入maven工程时出现错误有很多种可能性,下面是一些常见的解决方法:1. 检查项目的pom.xml文件是否正确:确保pom.xml...
    99+
    2023-09-15
    eclipse maven
  • eclipse导入appcompat项目报错解决办法
    eclipse导入appcompat项目报错解决办法我们在eclipse导入开源项目后,经常会发现找不到类似Theme.AppCompat.Light.DarkActionBar的style,解决办法也比较简单,就是导入com.androi...
    99+
    2023-05-31
    eclipse appcompat pp
  • eclipse导入maven工程报错怎么解决
    在Eclipse中导入Maven工程时可能会遇到各种错误。以下是一些常见的错误和解决方法:1. "Maven Integration...
    99+
    2023-08-18
    eclipse maven
  • eclipse导入web项目报错如何解决
    导入web项目报错可能是由于环境配置或者项目配置不正确导致的。以下是一些常见的解决方法:1. 确认环境配置:- 确保已经安装了Jav...
    99+
    2023-08-19
    eclipse
  • arco design按需导入报错如何解决
    本篇内容主要讲解“arco design按需导入报错如何解决”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“arco design按需导入报错如何解决”吧!记录一档使用arco...
    99+
    2023-07-05
  • oracle导入csv文件报错怎么解决
    在Oracle导入CSV文件时出现错误一般有以下几种常见原因和解决方法: 文件路径错误:确保CSV文件路径正确,没有拼写错误,可...
    99+
    2024-04-09
    oracle
  • Python导入csv文件报错怎么解决
    如果在导入CSV文件时出现错误,可以尝试以下几种方法来解决问题: 检查CSV文件的路径是否正确。确保在导入CSV文件时提供正确的...
    99+
    2024-04-02
  • plsql导入sql文件报错怎么解决
    在PL/SQL中导入SQL文件时,如果出现错误,可以按照以下步骤解决问题: 检查SQL文件的语法:确保SQL文件中的语法是正确的...
    99+
    2024-04-09
    plsql
  • mysql导入csv文件报错怎么解决
    如果在MySQL中导入CSV文件时遇到问题,一般有以下几种可能的解决方法: 确保CSV文件格式正确:检查CSV文件的格式是否符合...
    99+
    2024-04-18
    mysql
  • 如何解决navicat导入Excel报错的问题
    这篇文章将为大家详细讲解有关如何解决navicat导入Excel报错的问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。最近刚安装完navicat ,准备导入工作数据进去...
    99+
    2024-04-02
  • 导入maven的pom文件报错如何解决
    导入Maven的pom文件报错可能有很多原因。以下是一些常见的解决方法:1. 检查网络连接:确保您的网络连接正常。如果网络连接不稳定...
    99+
    2023-09-27
    maven
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作