(一)安装教程
1.在https://dev.mysql.com/downloads/mysql/下载压缩包(注意:网上的安装教程几乎都是低版本的mysql,所以一定要下载低版本的,我下载的是5.7.26,如果你装的是高版本的,并且没有成功,别担心文章后面有卸载教程)
2.将文件解压到安装目录,我解压到了D:\path。
注意:MySQL5.7与MySQL5.6不同,mysql5.6存在文件夹data,但是MySQL5.7没有,mysql5.6有my-defalult.ini,但是mysql5.7没有my-defalult.ini,需要自己手动建data文件夹和my.ini文件,mysql5.7需要初始化数据库
3.修改my.ini,并将下面的内容复制到my.ini,不过注意将basedir和datadir设置为自己的目录。
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=D:\path\mysql-5.7.26-winx64
# 设置mysql数据库的数据的存放目录
datadir=D:\path\mysql-5.7.26-winx64\data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
4.配置环境变量
将bin问价夹的目录添加到环境变量path中
D:\path\mysql-5.7.26-winx64\bin
5.以管理员身份运行cmd,并初始化数据库(必须以管理员身份运行cmd)
mysqld --initialize --user=mysql --console
记录下初始密码
6.安装服务
mysqld --install mysql
7.启动服务
net start mysql
8.链接mysql,使用上面的初始密码
mysql -u root -p
9.修改密码赋权限
#修改密码
set password for root@localhost = password('root');
flush privileges;
#赋予远程访问权限
grant all privileges on *.* to root@'%' identified by "root";
至此,数据库安装成功
(二)卸载教程
首先需要明确一点,用解压和cmd安装的形式,在控制面板的程序卸载中是找不到的,所以请按照下面的步骤卸载。
1.用cmd窗口命令来删除mysql服务: 在cmd中定位到压缩包解压的bin目录,输入:sc delete mysql
2.删除注册表:按 win+R键,输入regedit,确定
进入注册表编辑,找到
(1)HKEY_LOCAL_MACHINE\SYSTEM\ControlSet001\Services\Eventlog\Application\MySQLD 目录删除
(2)HKEY_LOCAL_MACHINE\SYSTEM\ControlSet002\Services\Eventlog\Application\MySQLD 目录删除 (我的电脑里并没有找到这一项,删了其它两项,成功完全删除)
(3)HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Eventlog\Application\MySQLD 目录删除
注意:这三个步骤里面你的电脑可能跟我的大小写不一致,不过没关系,这里不区分大小写;其次,你可能会在某一个里面找不到MySQLD目录,这是正常现象,我第一次卸载的时候第三个里面没有,第二系卸载的时候第二个和第三个里面都没有,但都卸载成功了。
3.删除文件。
这时候把你刚才解压的文件都删除(要先关闭cmd,否则可能会出现占用无法删除的情况),如果你删除成功,那么恭喜你已经将mysql卸载成功了,请忽略后面的步骤。如果你没有成功,那么下面的步骤4是为你准备的。
4.删除安装文件仍旧提示文件被占用,于是我就从文件的子目录一个一个的删除,后来发现是bin目录下的mysqld.exe这个一直提示被占用,怎么也删除不了,此时强制删除它,
进入cmd窗口,进入我的mysql安装目录的bin文件里,输入命令:mysqld.exe -remove,再到mysql安装目录去删除这个文件,可以成功删除,删除安装文件。
至此,恭喜你,mysql已经彻底删除,可以装另外的新的版本了。