SQL是Structured Query Language(结构化查询语言)的缩写。SQL是专为数据库而建立的操作命令集,是一种功能齐全的数据库语言。在使用它时,只需要发出“做什么”的命令,“怎么做”是不用使用者考虑的。SQL功能强大、简单易学、使用方便,已经成为了数据库操作的基础,并且现在几乎所有的数据库均支持SQL。 作为程序员,MySQL必定时我们会运用到的东西,而且很重要,可是有时候在工作中MySQL数据库难免会发生些问题,那么我们怎么去处理呢?下面我们就谈谈平常工作中会遇到的MySQL常见的一些问题及解决方案。 一、 忘记 MySQL 的 root 密码 1. 登录到数据库所在的服务器,手工 kill 掉 mysql 进程。 (1) 登录到数据库所在的服务器,手工 kill 掉 MySQL 进程: root@bogon:/data/mysql# kill `cat ./mysql.pid`
其中,mysql.pid 指的是 MySQL 数据目录下的 pid 文件,它记录了 MySQL 服务的进程号。 (2) 使用 --skip-grant-tables 选项重启 MySQL 服务: zj@bogon:/data/mysql$ sudo /usr/local/mysql/bin/mysqld --skip-grant-tables --user=root &
--skip-grant-tables 选项意思是启动 MySQL 服务时跳过权限表认证。启动后,连接到 MySQL 的 root 将不需要口令。 (3) 用空密码的 root 用户连接到 mysql ,并且更改 root 口令: zj@bogon:/usr/local/mysql/bin$ mysql -uroot
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 3Server version: 5.7.18-log Source distribution
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MySQL [(none)]> set password = password('123456');
ERROR 1290 (HY000): The MySQL server is running with the --skip-grant-tables option so it cannot execute this statementMySQL [(none)]> use mysql
Database changed
MySQL [mysql]> update user set authentication_string=password('123456') where user="root" and host="localhost";
Query OK, 1 row affected, 1 warning (0.02 sec)
Rows matched: 1 Changed: 1 Warnings: 1MySQL [mysql]> flush privileges;
Query OK, 0 rows affected (0.00 sec)
MySQL [mysql]> exit;
Bye
****************************************************************
zj@bogon:/usr/local/mysql/bin$ mysql -uroot -p123456
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 7Server version: 5.7.18-log Source distribution
Copyright (c) 2000, 2017, Oracle and/or its affiliates. All rights reserved.
Oracle is a registered trademark of Oracle Corporation and/or itsaffiliates. Other names may be trademarks of their respective
owners.
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MySQL [(none)]> 由于使用了 --skip-grant-tables 选项启动,使用 “set password” 命令更改密码失败,直接更新 user 表的 authentication_string(测试版本为5.7.18,有的版本密码字段是 ‘password’) 字段后,更改密码成功。刷新权限表,使权限认证重新生效。重新用 root 登录时,就可以使用刚刚修改后的口令了。 二、如何处理 myisam 存储引擎的表损坏 有的时候可能会遇到 myisam 表损坏的情况。一张损坏的表的症状通常是查询意外中断,并且能看到下述错误: 'table_name.frm' 被锁定不能更改 不能找到文件 'tbl_name.MYYI' (errcode:nnn) 文件意外结束 记录文件被毁坏 从表处理器得到错误 nnn。 通常有以下两种解决方法: 1. 使用 myisamchk 工具 使用 MySQL 自带的 myisamchk 工具进行修复: shell> myisamchk -r tablename
其中 -r 参数的含义是 recover,上面的方法几乎能解决所有问题,如果不行,则使用命令: shell> mysiamchk -o tablename
其中 -o 参数的含义是 --safe-recover,可以进行更安全的修复。 2. 使用 sql 命令 使用 MySQL 的 check table 和 repair table 命令一起进行修复,check table 用来检查表是否有损坏;repair table 用来对坏表进行修复。 三、 数据目录磁盘空间不足的问题 系统上线后,随着数据量的不断增加,会发现数据目录下的可用空间越来越小,从而给应用造成了安全隐患。 1. 对于 myisam 存储引擎的表 对于 myisam 存储引擎的表,在建表时可以用如下选项分别制定数据目录和索引目录存储到不同的磁盘空间,而默认会同时放在数据目录下: data directory = 'absolute path to directory'index directory = 'absolute path to directory'
如果表已经创建,只能先停机或者将表锁定,防止表的更改,然后将表的数据文件和索引文件 mv 到磁盘充足的分区上,然后在原文件处创建符号链接即可。 2. 对于 innodb 存储引擎的表 因为数据文件和索引文件是存放在一起的,所以无法将它们分离。当磁盘空间出现不足时,可以增加一个新的数据文件,这个文件放在充足空间的磁盘上。 具体实现方法是在参数 innodb_data_file_path 中增加此文件,路径写为新磁盘的绝对路径。 例如,如果 /home 下空间不足,希望在 /home1 下新增加一个可自动扩充数据的文件,那么参数可以这么写: innodb_data_file_path = /home/ibdata1:2000M;/home1/ibdata2:2000M:autoextend
参数修改后,必须重启数据库才可以生效。 四、DNS反向解析的问题 (5.0 以后的版本默认跳过域名逆向解析) 在客户端执行 show processlist 命令,有时会出现很多进程,类似于: unauthenticated user |