背景
MySQL是常用数据库,其中版本已经有很多了,安装方式也有很多,联网装、安装包等。不仅安装麻烦,卸载也很麻烦。因此笔者一般都是使用绿色版安装,安装过程自己很清晰,每一步都知道自己做了什么,卸载时也很容易,自己安装的时候做了什么,卸载的时候删除什么就行了。
版本
MySQL版本很多,而且版本之间的差异还很大,不像有的软件高版本很容易兼容低版本。比如MySQL5.5,这个以前是很多人用,但是现在基本不用了,那个版本大小写敏感。MySQL8.0,新版本有的人已经在用了,这个版本从安装开始就有很多坑,密码设置就让笔者体验很差,安装体验过,用的不爽就放弃了,笔者常用的是5.7.27,此版本比较稳定,装好了就不用操心了。
下载
在MySQL官网下载MySQL安装包,我们这里采用离线绿色安装,所以下载压缩包即可
下载地址:MySQL :: Download MySQL Community Server (Archived Versions)
在网站内选择下载的版本、系统、平台。就会筛选出对应的下载文件列表,这里可以看到有个zip压缩包可以下载。
安装
将压缩包解压到安装目录,笔者这里选的是D:\Program Files
配置MySQL环境变量,配置环境变量是为了在命令行中实用MySQL命令,如果只是使用,这不是必要操作。
在安装目录下新建一个my.ini 文件,这个文件是MySQL的配置文件
编辑my.ini文件,添加MySQL的配置信息
其中basedir就是解压的安装路径,datadir是MySQL数据存储路径,一般在安装路径中的/data目录,因为咱们是绿色版刚刚解压出来,所以还没有这个文件夹,不要紧,后面会有的
[mysql]
default-character-set=utf8
[mysqld]
port=3306
basedir="D:\Program Files\mysql-5.7.27-winx64"
datadir="D:\Program Files\mysql-5.7.27-winx64\data"
max_connections=200
character-set-server=utf8
default-storage-engine=INNODB
# 开启binlog
log_bin=mysql-bin
binlog-format=ROW
server-id=1001
使用管理员身份打开命令行,切换到D:\Program Files\mysql-5.7.27-winx64\bin路径,执行mysqld --initialize-insecure --user=mysql命令,初始化MySQL数据,这一步视电脑性能可能会需要一会,执行过程中不要关闭窗口。初始化完成后会生成上述配置的datadir目录,里面有MySQL初始化的数据,比如sys、mysql数据库等几个初始就有的数据库。
上述配置中添加了开启binlog,开启binlog可以实现MySQL数据库数据变化监控,默认是关闭的,也不用使用SQL语句修改这个属性,在配置文件中添加此配置就行。
# 开启binlog
log_bin=mysql-bin
binlog-format=ROW
server-id=1001
提示:在执行MySQL初始化时可能会出现缺少msvcr120.dll和msvcp120.dll文件的提示,这是因为每个电脑上的系统文件不同,MySQL需要这2个文件,正好你装的电脑上没有,一般在比较老的系统上安装会出现这个提示,比如win7,这个不要紧,在其它主机中找到这2个文件,可以用搜索软件,笔者用的是everything,这个不关键,一般电脑上会搜索到很多这个文件,有的软件安装也会携带这个文件,但是我们需要的是在C:\Windows\System32和C:\Windows\SysWOW64这2个系统文件夹中有这2个文件。我们在其它电脑上找到这2个文件件中的这2个文件,拷贝到需要安装的主机中就可以了。注意是2个文件夹中各2个文件
mysqld --initialize-insecure --user=mysql
继续在命令行中执行mysqld --install,安装MySQL服务。MySQL一般都是以服务的方式运行,所以这里需要此操作。
mysqld --install
MySQL服务安装成功后,在系统服务中启动MySQL
在命令行中执行mysql -uroot -p登录MySQL,需要输入密码,此版本安装后默认没有密码,可以直接登录
登录后查看MySQL的字符集,这个很关键,如果按照上述步骤操作的不会有问题,如果字符集不对,建议重新安装,否则后面很麻烦。
show variables like '%character%';
show variables like 'collation%';
查询字符集与上述一致说明没问题,是使用utf8字符集。
此安装完成后密码还是空的,我们可以修改密码,执行以下命令修改。此处就体现出MySQL版本之间的区别,不同版本修改账号密码的语句是不同的。
use mysql;
update user set authentication_string=password('密码') where user='root';
修改密码后需要重启MySQL,再次连接MySQL就需要输入你修改的密码了
远程连接
MySQL安装后默认只能本地连接,外部设备连接MySQL会被拒绝,可以通过配置允许远程连接。
命令行进入MySQL,查看以下数据
//切换到MySQL数据库
use mysql;
//在user表内查询host和user两列
select host,user from user;
可以看到user=root的host=localhost,说明root用户只能在本地登录,我们修改host为%通配符,表示所有地方都可以连接。
执行SQL
update user set host='%' where user='root';
重启MySQL,外部设备可以连接MySQL。