1、window版本mysql下载地址(下载没有问题,官网下载,可以下载8+版本,也可以下载5.x版本):https://dev.mysql.com/downloads/mysql/
2、下载完成为方便使用建议把bin目录配置到环境变量path中。
3、为方便使用,建议通过mysqld -install命令进行service服务安装。
4、dos下启动和关闭服务:net start mysql;net stop mysql必须在管理员环境下才可以使用
5、mysql官网下载解压版本没有my.ini配置文件,并且root的默认密码是空。一般用户都会进行修改密码,下面就开始遇到坑了,请注意解决方法:(配置文件可以从其他地方拷贝过来)
首先在没有密码的前提下我们是可以进入到mysql环境的,可以通过update语句进行修改密码:
update user set authentication_string='123' where user='root' and host='localhost';
修改完重启mysql,准备登陆,这个时候会发现刚刚修改的密码竟然不能登陆。why???
这个时候发现navicat连接数据库也报错。报错如下:
分析考虑可能是加密的方式不同,设置的密码所以不认识:这个时候网上给出了一系列的解决方法比如官网给出的通过设置一个密码然后用
C:\> mysqld --defaults-file="C:\\ProgramData\\MySQL\\MySQL Server 8.0\\my.ini" --init-file=C:\\mysql-init.txt
或者通过跳过权限检查的方法(此方法可以登陆并且修改密码,但是没有解决根本问题):
mysqld -nt --skip-grant-tables,进去之后窗口不能关闭,另外在开一个dos窗口。
以上方法都没有解决我的根本问题,后经分析考虑到应该是密码的加密存储方式的问题,于是用了以下的解决方案:
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER; #更改加密方式
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'; #更新用户密码
FLUSH PRIVILEGES; #刷新权限
此解决方案的前提是能够正常登陆到mysql,所以我在跳过权限的时候登陆进行把密码设置成了空,然后修改加密方式,修改密码,正常登陆。navicat也能正常连接。
这个时候密码的显示如下:
如果没有修改加密方式,直接update root用户的密码可以看到明文的密码形式。