文章目录
1. Windows 10 安装Mysql 5.7.27
我下载的安装包为release版本 之前没有安装过 所以查阅了网上的一些资料 安装过程记录如下
1.1 安装步骤
- 1、将安装包解压 放到任意的位置均可
- 2、配置用户系统变量和环境变量
⑴用户变量:变量值为解压后的目录位置
⑵环境变量:%MYSQL_HOME%\bin
⑶在根目录下添加一个名为my.ini
的文件夹
并将以下话粘贴进去
[mysqld]
port = 3306
basedir=C:\Program Files\mysql-5.7.29
datadir=C:\Program Files\mysql-5.7.29\data
max_connections=200
character-set-server=utf8
default-storage-engine=INNODB
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
[mysql]
default-character-set=utf8
需要注意的是:
basedir
和 datadir
需要自行设置为自己的目录位置
-
3、安装MySQL
⑴用管理员权限打开Power Shell,进入bin目录文件夹(我的为:C:\Program Files\mysql-5.7.29\bin
)
⑵再输入:.mysqld -install 命令 开始安装
如果出现这样的错误那就换一个方法
-
采用
.\mysqld.exe install
即可 -
输入
.\mysqld.exe -initialize -insecure -user=mysql
安装服务
注意这部分成功后没有结果 -
但是如果出现以下提示 即为这步操作失败了
-
上述操作若无效 则进入命令行管理员窗口 输入
mysqld --initialize-insecure
即可,无返回提示
根据提示可知 文件夹未在本地 将这两个位置改为自己的文件夹地址 并创建data文件加
–>成功后data
文件夹内应有这些文件!!:
即可解决报错 如图:(无提示即为成功)
-
最后一步 启动MySQL服务
–>net start mysql
-
如果无法启动 并且手动在 服务 中也无法启动 如下图:
则在此处属性对 “允许服务与桌面交互”打上勾即可解决(或者没有用管理员打开数据库)
-
新的问题:Mysql服务无法启动,清除data文件后,重回新安装musql服务 仍无法启动
-
若使用
net start mysql
提示找不到文件位置 并且regedit
进入服务中查看同样如此 可以先使用以下步骤重新安装服务:
1.mysqld --remove
清除服务
2.mysqld --install
安装服务 -
报错提示:
C:\WINDOWS\system32>net start mysql
MySQL 服务正在启动 …
MySQL 服务无法启动。
服务没有报告任何错误。
请键入 NET HELPMSG 3534 以获得更多的帮助。 -
解决办法:
①清空data文件夹中内容 并执行代码mysqld --initialize-insecure
data文件夹会出现下图中的数据
②登录: 启动mysql服务 + 登录数据库
2. 数据库备份与还原
2.1 备份服务器上的数据库
-
在Navicat中找到备份这一栏 选择备份即可
2.2 还原数据库
2.21 在本地数据库创建实例
-
1、设置密码
进入mysql 修改root密码默认的root密码是空的。
执行
mysql -uroot -p
回车进入 默认没密码
使用
set password = password('guohui');
来设置密码。 并刷新权限flush privileges
;
- 2、创建数据库实例 选择utf-8格式
- 3、正式开始备份
备份与还原有两种办法
第一种 将服务器的数据库导出到本地 然后再导入到新的数据库中
第二种(更加简单) Navicat提供一种复制数据库的功能 步骤如下:
按图片顺序找到数据传输工具
选择复制的数据源 再选择目的源 然后点击下一步即可
🐖:
- 1、以上操作存在一个问题 在数据库操作中 应当避免使用root用户直接执行操作 应创建一个具有数据库管理员权限的新用户:
mysql -u root -p //使用root账户进行登录
create user 'test'@'%' identified by 'test'; //创建用户 by后为密码
grant all privileges on *.* to 'test'@'%'; //授予所有数据库权限
flush privileges; //刷新权限缓存
结果如图:
- 2、记录另一个错误提示:
Navicat修改之前已经写好的连接时,测试连接通过,但是确定时提示错误
解决办法:欧凯 直接新建一个连接 - 3、表格数据传输失败
reference权限不足导致的失败(如下图)
问题猜想
是由于用户在doctor表中缺少其reference权限导致,添加该权限即可
show grants for VR //查询用户权限
grant references on doctor.* to VR@'xxx.xxx.xxx.xxx'//授权
或者在Navicat中找到mysql
--> user
—> Reference_priv
和 Alter_priv
将对应的VR的值改为Y即可
然后在进行数据传输 可以成功
但是用VR数据库作为源则会失败 未找到原因
3.推荐绿色版Navicat
- 该版本较低,语言只有英文,但不碍于使用,并且直接安装输入码即可(文件中),推荐使用!!(固定5积分)
(已完成上传)
CSDN下载地址