mysql重置密码出现的一系列问题

2024-04-09 21:38

本文主要是介绍mysql重置密码出现的一系列问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

本人初识mysql, 输入mysql -u root -p,出现enter password,我直接点击回车,出现了如下错误提示:

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

大概一些朋友也是在网上看到过这样的错误,并且表示比较好解决,大概意思是密码错误之类的,但是那是不可能的,紧接着这个错误,噩梦开始了:会连续出现很多错误,最后还是解决了,方法都是网上找来的,如果哪里侵权了我会及时改正谢谢!
第一步:
#1.停止mysql数据库
/etc/init .d /mysqld  stop
#2.执行如下命令
mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
#3.使用root登录mysql数据库
mysql -u root mysql
#4.更新root密码
mysql> UPDATE user SET Password=PASSWORD( 'newpassword' ) where USER= 'root' ;
#最新版MySQL请采用如下SQL:
mysql> UPDATE user SET authentication_string=PASSWORD( 'newpassword' ) where USER= 'root' ;
#5.刷新权限 
mysql> FLUSH PRIVILEGES;
#6.退出mysql
mysql> quit
#7.重启mysql
/etc/init .d /mysqld  restart
#8.使用root用户重新登录mysql
mysql -uroot -p 
Enter password: <输入新设的密码newpassword>

这是网上找的第一种方法,还有一种是修改etc/my.conf配置文件,但是最无奈的是我的配置文件是空的。。。相关链接文件也是,当然了我的问

题不是那么好解决的,到了第二步:跳过安全检查时出现了问题:
mysqld_safe Directory ‘/var/run/mysqld’ for UNIX socket file don’t exists
解决方法如下:   mkdir -p / var /run/mysqld
chown mysql:mysql / var /run/mysqld
/usr/bin/mysqld_safe --skip-grant-tables &
然后再开启另一个终端登录mysql,就可以跳过安全认证了。
但你以为这一切都结束了?不!在更改密码时再次报错:

ERROR 1054 (42S22): Unknown column 'password' in 'field list'

大神给的解释是:
原来是mysql数据库下已经没有password这个字段了,password字段改成了 authentication_string

所以更改语句替换为update mysql.user set authentication_string=password('root') where user='root' ;即可

当然,一切修改完之后在启动mysql时又出现了问题:

ERROR 2002 (HY000):Can't connect to local MySQL server

这个问题我的原因是之前以安全模式进入mysql结果没有关掉,结束mysql_safe相关进程就ok了,但是出现这个问题的其他原因也挺多的,我也一并贴了出来供大家参考:

方案1.
1.#ps -A|grep  mysql
显示类似:
1829 ?        00:00:00 mysqld_safe
   1876 ?        00:00:31 mysqld
2.#kill -9 1829
3.#kill -9 1876
4.#/etc/init.d/ mysql restart
5.# mysql -u root -p
他的麻烦解决了,我的还没解决!
继续找
方案2
先查看 /etc/rc.d/init.d/mysqld status 看看m y s q l 是否已经启动.
另外看看是不是权限问题.
------------------------------------------------------------------------------------
[root@localhost beinan]#chown -R mysql:mysql /var/lib/mysql
[root@localhost beinan]# /etc/init.d/mysqld start
启动 MySQL: [ 确定 ]
[root@localhost lib]# mysqladmin -uroot password '123456'
[root@localhost lib]# mysql -uroot -p
Enter password:
Welcome to the MySQL monitor. Commands end with ; or /g.
Your MySQL connection id is 3 to server version: 4.1.11

Type 'help;' or '/h' for help. Type '/c' to clear the buffe
他的也解决了,我的麻烦还在继续,依然继续寻找
方案3
问题解决了,竟然是max_connections=1000 他说太多了,然后改成500也说多,无奈删之问题解决了。
还是不行
方案4
/var/lib/mysql 所有文件权限 改成mysql.mysql
不行不行
方案5
摘要:解决不能通过 mysql .sock连接MySQL问题 这个问题主要提示是,不能通过 '/tmp/ mysql.sock'连到服务器,而php标准配置正是用过'/tmp/ mysql .sock',但是一些 mysql 安装 方法 将  mysql.sock放在/var/lib/ mysql .sock或者其他的什么地方,你可以通过修改/etc/my.cnf文件来修正它,打开文件,可以看到如下的东东:

   [mysql d] 
  socket=/var/lib/mysql .sock 
  改一下就好了,但也会引起其他的问题,如mysql 程序连不上了,再加一点: 
  [mysql ] 
  socket=/tmp/mysql .sock 
  或者还可以通过修改php.ini中的配置来使php用其他的mysql .sock来连,这个大家自己去找找
  
  或者用这样的方法:
  ln -s /var/lib/mysql /mysql .sock /tmp/mysql .sock

成功了,就是这样ln -s /var/lib/mysql /mysql .sock /tmp/mysql .sock

OK!



终于,噩梦结束了。。。其实简单来说就是跳过mysql的密码验证,然后对密码进行修改就ok了,没想到我中间会出这么多岔子。。。如果有相同经历的同学可以参照我整理的错误,可能有点乱哈,第一次弄,哪里说得不对也欢迎指正!




这篇关于mysql重置密码出现的一系列问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/889280

相关文章

SQL中JOIN操作的条件使用总结与实践

《SQL中JOIN操作的条件使用总结与实践》在SQL查询中,JOIN操作是多表关联的核心工具,本文将从原理,场景和最佳实践三个方面总结JOIN条件的使用规则,希望可以帮助开发者精准控制查询逻辑... 目录一、ON与WHERE的本质区别二、场景化条件使用规则三、最佳实践建议1.优先使用ON条件2.WHERE用

MySQL存储过程之循环遍历查询的结果集详解

《MySQL存储过程之循环遍历查询的结果集详解》:本文主要介绍MySQL存储过程之循环遍历查询的结果集,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言1. 表结构2. 存储过程3. 关于存储过程的SQL补充总结前言近来碰到这样一个问题:在生产上导入的数据发现

MySQL 衍生表(Derived Tables)的使用

《MySQL衍生表(DerivedTables)的使用》本文主要介绍了MySQL衍生表(DerivedTables)的使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录一、衍生表简介1.1 衍生表基本用法1.2 自定义列名1.3 衍生表的局限在SQL的查询语句select

MySQL 横向衍生表(Lateral Derived Tables)的实现

《MySQL横向衍生表(LateralDerivedTables)的实现》横向衍生表适用于在需要通过子查询获取中间结果集的场景,相对于普通衍生表,横向衍生表可以引用在其之前出现过的表名,本文就来... 目录一、横向衍生表用法示例1.1 用法示例1.2 使用建议前面我们介绍过mysql中的衍生表(From子句

六个案例搞懂mysql间隙锁

《六个案例搞懂mysql间隙锁》MySQL中的间隙是指索引中两个索引键之间的空间,间隙锁用于防止范围查询期间的幻读,本文主要介绍了六个案例搞懂mysql间隙锁,具有一定的参考价值,感兴趣的可以了解一下... 目录概念解释间隙锁详解间隙锁触发条件间隙锁加锁规则案例演示案例一:唯一索引等值锁定存在的数据案例二:

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

MYSQL查询结果实现发送给客户端

《MYSQL查询结果实现发送给客户端》:本文主要介绍MYSQL查询结果实现发送给客户端方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql取数据和发数据的流程(边读边发)Sending to clientSending DataLRU(Least Rec

MySQL分区表的具体使用

《MySQL分区表的具体使用》MySQL分区表通过规则将数据分至不同物理存储,提升管理与查询效率,本文主要介绍了MySQL分区表的具体使用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、分区的类型1. Range partition(范围分区)2. List partition(列表分区)3. H

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig