在写这篇文章前,我弄好了,写完之后把成功安装的几个MySQL都删除了,只留了最后测试成功的服务"mysql-test" ,然后点击运行,发现又出现上图的错误。心态炸了。
本以为定位到问题了,但是这个错误让我迷茫了。我只能临时记录下可能的地方,因为我改来改去大概就这几个地方了。然后就成功了
改动的地方有:(以下都是基于免安装版本的mysql8.0.26,操作之前必须要备份啊)
以下不是步骤,只是说了关键点,我想定位问题来着,但是太花时间了。另外这个my.ini文件本身也有点问题,太费时间了。这篇文章更多的是我一个临时记录。以后找到问题再更新文章
1、在my.ini中加入innodb_force_recovery=1,然后重启mysql服务
[mysqld]
innodb_force_recovery=1
2、在data文件夹下找到xxx.err 文件,然后把里面的内容清空,然后重启mysql服务
3、打开命令窗执行下mysql -V 看有没有报错
4、看下环境变量,记得看path变量是否有。这里要说下。安装mysql服务时,跟这个变量有关系的,你可以选择mysql服务,右击看属性就知道它关联的是哪个my.ini文件。明白了这点后,你的电脑可以使用很多个不同版本的mysql都不是问题。设置环境变量只是方便任何路径可以使用
5、安装mysql服务命令
mysqld install mysql8 --defaults-file="C:\XSoft\mysql\my.ini"
mysql8: 自定义服务名
C:\XSoft\mysql\my.ini 换成你自己的
6、删除服务
sc delete mysql8
7、把360关了
8、my.ini文件
某个老6的my.ini文件
[mysqld]
#设置后不需要密码进入mysql
#skip-grant-tables
设置3306端口
port=3306
设置mysql的安装目录 ----------是你的文件路径-------------
basedir=C:\XSoft\mysql
设置mysql数据库的数据的存放目录 ---------是你的文件路径data文件夹自行创建
#datadir=C:\XSoft\mysql\data
允许最大连接数
max_connections=200
允许连接失败的次数。
max_connect_errors=1000
服务端使用的字符集默认为utf8mb4
character-set-server=utf8mb4
创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
默认使用"mysql_native_password"插件认证
#mysql_native_password
default_authentication_plugin=mysql_native_password
add the length to the max
group_concat_max_len = 1024000
[mysql]
设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8mb4
我又从其他地方拷一个来参考
[mysqld]
设置端口,默认3306
port=3306
设置mysql的安装目录
basedir=C:\\Program Files\\mysql-8.0.17-winx64
设置mysql数据库的数据的存放目录
datadir=C:\\Program Files\\mysql-8.0.17-winx64\\data
允许最大连接数
max_connections=200
允许连接失败的次数。这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
服务端使用的字符集默认为UTF8
character-set-server=utf8mb4
创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
[mysql]
设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8mb4
9、初始化数据库 mysqld --initialize --user=mysql --console。但是吧,这个初始化前,还是把data文件备份下。可以把data目录改成其他名字,然后新建一个data目录