当前位置: 首页 > news >正文

Windows环境下安装 mysql-8.0.11-winx64 遇到的问题解决办法

下载mysql安装包,我的是下载mysql-8.0.11-winx64,解压到你想安装的目录下,然后配置环境(window环境下,mac本还没试过),

1、首先,配置环境:右击此电脑->属性->高级系统设置->环境变量->path->新建 ,然后将自己的路径添加进去(例如我目录:F:\mysql\mysql-8.0.11-winx64),除此之外还要看解压的压缩包内是否有my.ini文件或者my-default.ini文件,如果没有需要自己写一个在根目录下,默认的配置信息如下:

查看所有的配置项,可参考:https://dev.mysql.com/doc/refman/8.0/en/mysqld-option-tables.html

[mysqld]
# 设置3306端口
port=3306
# 设置mysql的安装目录
basedir=F:\mysql\mysql-8.0.11-winx64
# 设置mysql数据库的数据的存放目录(此目录会在之后进行命令生成,无需手写)
datadir=F:\mysql\mysql-8.0.11-winx64\Data
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。这是为了防止有人从该主机试图攻击数据库系统
max_connect_errors=10
# 服务端使用的字符集默认为UTF8
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件认证
default_authentication_plugin=mysql_native_password
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8

2、然后打开终端,window+r 然后输入cmd 打开终端并切换到该路径下,并执行命令 mysqld --initialize 检查当前环境,如果没有任何报错,打开你的目录你会看到你的根目录会出现data文件夹;说明一切正常

1073936-20181029171607503-1453112665.png

注意这一步可能会遇到一些报错信息,例如弹出“ 由于找不到vcruntime140.dll,无法继续执行代码,重新安装程序可能会解决此问题 ”等问题,说明你的电脑缺少一些必要的文件,这时要打开控制面板查看C++ 2015具体信息,

1073936-20181029171853479-1524443631.png
我的是因为之前没有x64位的C++,所以缺少文件,如果你的有,那么可点击卸载,它会提示你让你进行修复,点击修复,完成,就可以继续在终端输入命令;

初始化数据库

mysqld --initialize --console

这时会打印如下error,意思是已经有了data目录了,只要把他删除就好,

F:\mysql\mysql-8.0.11-winx64\bin>mysqld --initialize --console
2018-10-29T09:26:35.244245Z 0 [System] [MY-013169] [Server] F:\mysql\mysql-8.0.11-winx64\bin\mysqld.exe (mysqld 8.0.11) initializing of server in progress as process 980
2018-10-29T09:26:35.287469Z 0 [ERROR] [MY-010457] [Server] --initialize specified but the data directory has files in it. Aborting.
2018-10-29T09:26:35.299110Z 0 [ERROR] [MY-010119] [Server] Aborting
2018-10-29T09:26:35.302159Z 0 [System] [MY-010910] [Server] F:\mysql\mysql-8.0.11-winx64\bin\mysqld.exe: Shutdown complete (mysqld 8.0.11)  MySQL Community Server - GPL.

再次执行上面命令,会打印用户的初始密码,其中@localhost : XXXXXX就是默认密码,需要记住,如果没有记住,就将后来生成的data文件删除,再次生成也是可以的

F:\mysql\mysql-8.0.11-winx64\bin>mysqld --initialize --console
2018-10-29T09:28:49.177043Z 0 [System] [MY-013169] [Server] F:\mysql\mysql-8.0.11-winx64\bin\mysqld.exe (mysqld 8.0.11) initializing of server in progress as process 12980
2018-10-29T09:29:19.270535Z 5 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: kw3AlnY_g.Dg
2018-10-29T09:29:41.684599Z 0 [System] [MY-013170] [Server] F:\mysql\mysql-8.0.11-winx64\bin\mysqld.exe (mysqld 8.0.11) initializing of server has completed

3、然后安装服务, mysqld --install[服务名] 如果只有一个服务可以不写默认mysql,如果多个服务可以写具体的服务名称,XXXX,当回车之后,又出现错误, install/remove of the service deined,这是由于运行cmd的时候不是用管理员的身份运行的,只要再次以管理员的命令运行cmd就可以了,出现service successfully installed 说明服务安装好了。

F:\mysql\mysql-8.0.11-winx64\bin>mysqld --install
Service successfully installed.

4、启动服务,运行命令 : net start mysql ,看到服务已经启动成功

F:\mysql\mysql-8.0.11-winx64\bin>net start mysql
MySQL 服务正在启动 ....
MySQL 服务已经启动成功。

5、更改密码和密码认证插件 ,

在MySQL安装目录的 bin 目录下执行命令:mysql -u root -p

F:\mysql\mysql-8.0.11-winx64\bin>mysql -u root -p
Enter password: *******
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

这时要重新生成密码,删除data目录,运行mysqld --initialize --console,

F:\mysql\mysql-8.0.11-winx64\bin>mysqld --initialize --console
2018-10-29T10:04:23.337650Z 0 [System] [MY-013169] [Server] F:\mysql\mysql-8.0.11-winx64\bin\mysqld.exe (mysqld 8.0.11) initializing of server in progress as process 7928
2018-10-29T10:05:19.210237Z 5 [Note] [MY-010454] [Server] A temporary password is generated for root@localhost: RXZG!fJR2Ly+
2018-10-29T10:06:00.603070Z 0 [System] [MY-013170] [Server] F:\mysql\mysql-8.0.11-winx64\bin\mysqld.exe (mysqld 8.0.11) initializing of server has completed

重新执行mysql -u root -p,填入密码(注意密码左右没有空格),这时会打印出相关的信息

F:\mysql\mysql-8.0.11-winx64\bin>mysql -u root -p
Enter password: ************
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 8
Server version: 8.0.11

Copyright (c) 2000, 2018, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

修改用户密码,在MySQL中执行命令:ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '新密码';,出现下面情况就证明你已经修改成功。

mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '5502yulijian.';
Query OK, 0 rows affected (0.17 sec)

show databases; (‘;’一定要加

1073936-20181029184240082-1700200165.png

这样就可以了

转载于:https://www.cnblogs.com/oxiaojiano/p/9881927.html

相关文章:

  • LinuxMint下Docker的安装部署和验证
  • Vue-cli / webpack 加载静态js文件的方法
  • python函数的动态传参.作用域与命名空间
  • static DEVICE_ATTR(val, S_IRUGO | S_IWUSR, hello_val_show, hello_val_store); 的作用
  • 几分钟内提升技能的8个 JavaScript 方法!
  • HTTP请求中的form data和request payload的区别
  • Linux内核-协议栈-从BSD Socket接口层到传输层1
  • centos7全离线安装MongoDB3.2.8集群
  • Java基础学习18(类的多态性以及子父类之间的转换机制)
  • Python的三种基本数据类型
  • 窗体数据Excle导入功能详解
  • Linux -LAMP架构介绍
  • 2018-2019-1 20165226 20165310 20165315 实验二 固件程序设计
  • html5本地存储
  • SQL Join 图示
  • 【笔记】你不知道的JS读书笔记——Promise
  • 【跃迁之路】【585天】程序员高效学习方法论探索系列(实验阶段342-2018.09.13)...
  • ESLint简单操作
  • FastReport在线报表设计器工作原理
  • If…else
  • Java教程_软件开发基础
  • JS字符串转数字方法总结
  • leetcode388. Longest Absolute File Path
  • miaov-React 最佳入门
  • Vue2.0 实现互斥
  • 初识 beanstalkd
  • 从零开始的无人驾驶 1
  • 从零开始在ubuntu上搭建node开发环境
  • ------- 计算机网络基础
  • 解析带emoji和链接的聊天系统消息
  • 微信小程序填坑清单
  • 小程序、APP Store 需要的 SSL 证书是个什么东西?
  • 携程小程序初体验
  • 移动端解决方案学习记录
  • Play Store发现SimBad恶意软件,1.5亿Android用户成受害者 ...
  • ​Linux·i2c驱动架构​
  • (C)一些题4
  • (九十四)函数和二维数组
  • (六) ES6 新特性 —— 迭代器(iterator)
  • (七)c52学习之旅-中断
  • (四)库存超卖案例实战——优化redis分布式锁
  • (转)memcache、redis缓存
  • (转)Oracle 9i 数据库设计指引全集(1)
  • (转)ORM
  • .gitignore文件---让git自动忽略指定文件
  • .NET Core 控制台程序读 appsettings.json 、注依赖、配日志、设 IOptions
  • .net 调用php,php 调用.net com组件 --
  • .Net8 Blazor 尝鲜
  • .NET基础篇——反射的奥妙
  • .NET开发人员必知的八个网站
  • .NET开源项目介绍及资源推荐:数据持久层 (微软MVP写作)
  • [ArcPy百科]第三节: Geometry信息中的空间参考解析
  • [BZOJ 3680]吊打XXX(模拟退火)
  • [BZOJ 4034][HAOI2015]T2 [树链剖分]
  • [C# WPF] 如何给控件添加边框(Border)?