MySQL数据库常见报错案例与错误代码说明

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: MySQL数据库常见报错案例与错误代码说明

实例报错问题分析与解决方法:


-报错1

Can’t open file: ‘xxx_forums.MYI’. (errno: 145)

问题分析:


这种情况是不能打开 cdb_forums.MYI造成的,引起这种情况可能的原因有:


?1、服务器非正常关机,数据库所在空间已满,或一些其它未知的原因,对数据库表造成了损坏。


?2、类 unix 操作系统下直接将数据库文件拷贝移动会因为文件的属组问题而产生这个错误。


解决方法:


1、修复数据表


可以使用下面的两种方式修复数据表:(第一种方法仅适合独立主机用户)


?1)使用myisamchk ,MySQL 自带了专门用户数据表检查和修复的工具 ——myisamchk。更改当前目录到MySQL/bin下面,一般情况下只有在这个下面才能运行myisamchk命令。常用的修复命令为:myisamchk -r数据文件目录/数据表名.MYI;


?2)通过 phpMyAdmin 修复, phpMyAdmin 带有修复数据表的功能,进入到某一个表中后,点击“操作”,在下方的“表维护”中点击“修复表”即可。


?注意:以上两种修复方式在执行前一定要备份数据库。


2、修改文件的属组(仅适合独立主机用户)


?1)复制数据库文件的过程中没有将数据库文件设置为 MySQL 运行的帐号可读写(一般适用于 Linux和 FreeBSD 用户)。


-报错2

ERROR 1045 (25000): Access denied for user 'root'@'localhost' (using password: NO)

问题分析:


?密码不正确或者没有权限访问。


解决方法:


1)修改 my.cnf 主配置文件,在 [mysqld] 下添加 skip-grant-tables,重启数据库。


??最后修改密码命令如下:

mysql> use mysql;
mysql> update user set password=password("123qqq...A") where user="root";

??删除刚刚添加的 skip-grant-tables 参数,再重启数据库,使用新密码即可登录。


2)重新授权,命令如下:

mysql> grant all on *.* to 'root'@'mysql-server' identified by '123qqq...A';

-报错3

Duplicate key name ‘xxx’

问题分析:


?要创建的索引已经存在,会引发这个错误,这个错误多发生在升级的时候。可能是已经升级过的,重复升级引起的错误。也有可能是之前用户擅自加的索引,刚好与升级文件中的索引相同了。


解决方法:


?看看已经存在的索引和要添加的索引是否一样,一样的话可以跳过这条sql语句,如果不一样那么现删除已存在的索引,之后再执行。


-报错4

Table ‘xxx’ already exists

问题分析:


?xxx表已经存在于库中,再次创建这个名字的表就会引发该错误。


解决方法:


?查看已经存在的表是否和将要创建的表完全一样,一样的话可以跳过不执行这个sql,否则请将存在的表先删除,再执行。


-报错5

InnoDB: Error: page 14518 log sequence number 5698741252 InnoDB: is in the future! Current system log sequence number 5698741252

问题分析:


?innodb 数据文件损坏。


解决方法:


?修改 my.cnf 配置文件,在 [mysqld] 下添加 innodb_force_recovery=4, 启动数据库后备份数据文件,然后再去掉该参数,利用备份文件恢复数据。


-报错6


?从库的 Slave_IO_Running 状态为 NO


问题分析:


?主库和从库的 server-id 值一样。


解决方法:


?修改从库的 server-id 的值,修改成与主库不一样,比主库低。修改完成后重启,再同步即可!


-报错7

Warning: World-writable config file '/etc/my.cnf' is ignored ERROR! MySQL is running but PID file could not be found

问题分析:


?MySQL 的配置文件 /etc/my.cnf 权限不对。


解决方法:

chmod 644 /et/my.cnf

-报错8

Too many connections (1040)链接过多

问题分析:


?连接数已经超过了mysql设置的值,与max_connections 和wait_timeout 都有关系。wait_timeout的值越大,连接的空闲等待就越长,这样就会造成当前连接数越大


解决方法:


?优化 MySQL 服务器的配置,可参考修改 MySQL 配置文件my.ini或者 my.cnf中的参数:


?max_connections= 1000 ?wait_timeout = 10


?修改后重启 MySQL ,如果经常性的报此错误,需做一下服务器的整体优化。


-报错9

Can’t connect to MySQL server on ‘localhost’ (10061)

问题分析:


?说明机器上没提供MySQL服务。需要启动这台机器上的MySQL服务,如果负载太高也会产生这个错误。


解决方法:


?启动这台机器的mysql服务,如果启动不成功,多数是因为你的my.ini配置的有问题,重新配置其即可。如果觉得mysql负载异常,可以到mysql/bin 的目录下执行mysqladmin -uroot -p123 processlist来查看mysql当前的进程。


-报错10

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/data/mysql/mysql.sock'

问题分析:


?可能是数据库没有启动或者是端口被防火墙禁止。


解决方法:


?启动数据库或者防火墙开放数据库监听端口。


-报错11

Error initializing relay log position: I/O error reading the header from the binary log

问题分析:


?从库的中继日志 relay-bin 损坏.


解决方法:


?手动修复,重新找到同步的 binlog 和 pos 点,然后重新同步即可。

mysql> CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.xxx',MASTER_LOG_POS=xxx;

-报错12


?从库的 Slave_IO_Running 为 NO 问题


问题分析:


?造成从库线程为 NO 的原因会有很多,主要原因是主键冲突或者主库删除或更新数据, 从库找不到记录,数据被修改导致。


?通常状态码报错有 1007、1032、1062、1452 等。


解决方法一:

mysql> stop slave;
mysql> set GLOBAL SQL_SLAVE_SKIP_COUNTER=1;
mysql> start slave;

解决方法二:设置用户权限,设置从库只读权限

set global read_only=true;
set GLOBAL max_connections=10000;

-报错13


?客户端报 Too many connections


问题分析:


?连接数超出 Mysql 的最大连接限制。


解决方法:


?在 my.cnf 配置文件里面增加连接数,然后重启 MySQL 服务。max_connections = 10000临时修改最大连接数,重启后不生效。需要在 my.cnf 里面修改配置文件,下次重启生效。


-报错14

Got error 28 from table handler

问题分析:


?数据库所在磁盘空间已满。


解决方法:


?增加 MySQL 所在的磁盘空间或者清理一些无用文件。


-报错15

Can’t create a new thread; if you are not out of available memory, you can consult the manual for a possible OS-dependent bug。

问题分析:


?数据库服务器问题,数据库操作无法创建新线程。一般是两个原因:


??1.服务器系统内存溢出。


??2.环境软件损坏或系统损坏。


解决方法:


?检查服务器的内存和系统是否正常,如果服务器内存紧张,请排查一下哪些进程消耗了服务器的内存,同时考虑是否增加服务器的内存来提高整个的负载能力。


Mysql常见错误代码说明:

130 :文件格式不正确
145 :文件无法打开
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:字段不存在
1065:无效的 SQL 语句,SQL 语句为空
1081:不能建立 Socket 连接
1114:数据表已满,不能容纳任何记录
1116:打开的数据表太多
1129:数据库出现异常,请重启数据库
1130:连接数据库失败,没有连接数据库的权限
1133:数据库用户不存在
1141:当前用户无权访问数据库
1142:当前用户无权访问数据表
1143:当前用户无权访问数据表中的字段
1146:数据表不存在
1147:未定义用户对数据表的访问权限
1149:SQL 语句语法错误
1158:网络错误,出现读错误,请检查网络连接状况
1159:网络错误,读超时,请检查网络连接状况
1160:网络错误,出现写错误,请检查网络连接状况
1161:网络错误,写超时,请检查网络连接状况
1062:字段值重复,入库失败
1169:字段值重复,更新记录失败
1177:打开数据表失败
1180:提交事务失败
1181:回滚事务失败
1203:当前用户和数据库建立的连接已到达数据库的最大连接数,请增大可用的数据库连接数或重启数据库
1205:加锁超时
1211:当前用户没有创建用户的权限
1216:外键约束检查失败,更新子表记录失败
1217:外键约束检查失败,删除或修改主表记录失败
1226:当前用户使用的资源已超过所允许的资源,请重启数据库或重启服务器
1227:权限不足,您无权进行此操作
1235:MySQL 版本过低,不具有本功能
1250:客户端不支持服务器要求的认证协议,请考虑升级客户端。
1251:Client 不能支持 authentication protocol 的要求 Client does not support authentication protocol requested by server; consider upgrading MySQL clientQuote:
1267:不合法的混合字符集。
2002:服务器端口不对。
2003:MySQL 服务没有启动,请启动该服务。
2008:MySQL client ran out of memory 错误指向了 MySQL 客户 mysql。这个错误的原因很简单,客户没有足够的内存存储全部结果。
2013:远程连接数据库是有时会有这个问题,MySQL 服务器在执行一条 SQL 语句的时候失去了连接造成的。
10048: 建议在 my.ini 文件中修改最大连接数, 把 mysql_connect () 方法都改成了 mysql_pconnect () 方法。要修改 mysql_pconnect (),可以在论坛的 data 目录的 sql_config.php 中 p c o n n e c t = 0 ; // 是 否 持 久 连 接 修 改 成 pconnect = 0; // 是否持久连接 修改成 pconnect=0;// 是否持久连接修改成 pconnect = 1; 开启防刷新,严禁刷新太快.
10055: 没有缓存空间可利用,查看下你的 C 盘空间是否已经满,清除一些没有用的文件。可以在后台的 "论坛核心设置","核心功能设置" 里 "进程优化" 开启,"GZIP 压缩输出" 关闭。查找了一下 10055(没有缓存空间可利用)
10061: 启动这台机器上的 MySQL 服务 如服务启动失败,一定是你的 my.ini 文件出了差错, MySQL 服务不能正常启动 你删除了它后,MySQL 就会按其默认配置运行, 那就没有问题了。


相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1天前
|
Oracle 关系型数据库 MySQL
实时计算 Flink版操作报错合集之用CTAS从mysql同步数据到hologres,改了字段长度,报错提示需要全部重新同步如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
24 8
|
1天前
|
SQL 关系型数据库 MySQL
实时计算 Flink版操作报错合集之程序初始化mysql没有完成就报错如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
12 4
|
1天前
|
关系型数据库 MySQL 数据库
实时计算 Flink版操作报错合集之sqlserver mysql都用的胖包,sqlserver的成功了,mysql报这个错如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
16 6
|
1天前
|
SQL Oracle 关系型数据库
实时计算 Flink版操作报错合集之连接器换成2.4.2之后,mysql作业一直报错如何解决
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
12 3
|
4天前
|
前端开发 easyexcel 关系型数据库
EasyExcel处理Mysql百万数据的导入导出案例,秒级效率,拿来即用!
EasyExcel处理Mysql百万数据的导入导出案例,秒级效率,拿来即用!
12 1
|
4天前
|
SQL 存储 小程序
数据库数据恢复—Sql Server数据库文件丢失的数据恢复案例
数据库数据恢复环境: 5块硬盘组建一组RAID5阵列,划分LUN供windows系统服务器使用。windows系统服务器内运行了Sql Server数据库,存储空间在操作系统层面划分了三个逻辑分区。 数据库故障: 数据库文件丢失,主要涉及3个数据库,数千张表。数据库文件丢失原因未知,不能确定丢失的数据库文件的存放位置。数据库文件丢失后,服务器仍处于开机状态,所幸未写入大量数据。
数据库数据恢复—Sql Server数据库文件丢失的数据恢复案例
|
4天前
|
SQL 存储 数据挖掘
数据库数据恢复—数据库ndf文件大小变为0KB的数据恢复案例
存储设备损坏导致存储中SQL Server数据库崩溃。对数据库文件进行恢复后,用户发现有4个ndf文件的大小变为0KB。该SQL Server数据库每10天生成一个大小相同的NDF文件,该SQL Server数据库包含两个LDF文件。
|
4天前
|
关系型数据库 MySQL 数据库
MySQL 启动 登录报错Job for mysqld.service failed because the control process exited with error code. See
MySQL 启动 登录报错Job for mysqld.service failed because the control process exited with error code. See
|
4天前
|
SQL 数据可视化 关系型数据库
【MySQL-11】多表查询全解-【多表关系/内外自连接/子查询/多表查询案例链接】(可cv代码&案例演示)
【MySQL-11】多表查询全解-【多表关系/内外自连接/子查询/多表查询案例链接】(可cv代码&案例演示)
|
4天前
|
关系型数据库 MySQL Linux
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)
【MySQL-10】数据库函数-案例演示【字符串/数值/日期/流程控制函数】(代码演示&可cv代码)

推荐镜像

更多
http://www.vxiaotou.com