前言
写这个的主要目的是,由于最近有点忘事,刚好现在又重装了操作系统。所以还是写下来做个备忘好了,也希望能帮助到一些小伙伴。
1、安装环境:
Windows 10
MySQL-8.0.12(送你去下载)
注:下载材料主要是我现在使用的版本,也是官网的包,可以自己检验一下MD5,官网最新的应该是8.0.16了,200多M有点大,所以我用8.0.12的。具体的下载步骤就不截图了,需要安装最新版的,自己动手吧
2、MySQL安装操作
解压MySQL压缩版:
将压缩包解压到自己想安装的目录2.1、配置环境变量:
变量名:MYSQL_HOME
变量值:D:\spaces\mysql_8.0.12
并在path中加入:
环境变量%MYSQL_HOME%\bin;
2.2、创建依赖文件:
由于高版本的MySQL需要自己创建一个data的文件夹和后缀名为.ini的初始化文件,so自行创建辽
自行创建data和后缀.ini文件2.3、.ini文件配置:
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[mysqld]
explicit_defaults_for_timestamp=true
#设置3306端口
port = 3306
# 设置mysql的安装目录
basedir=%MYSQL_HOME%
# 设置mysql数据库的数据的存放目录
datadir=%MYSQL_HOME%\data
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES
注:这个是我自己习惯用的,有其他需求可参照官方文档进行修改(官方文档)
2.4、初始化MySQL:
以管理员权限打开cmd命令行,由于已经配置了MySQL环境变量,所以不需要cd进入到MySQL的bin目录,直接开搞
//生成空密码
mysqld --initialize-insecure --console
或者
//生成临时密码
mysqld --initialize --console
执行生成空密码
一般选择生成空密码执行后,会有以下输出:
2019-07-21T15:46:55.451034Z 0 [System] [MY-013169] [Server] D:\spaces\mysql_8.0.12\bin\mysqld.exe (mysqld 8.0.12) initializing of server in progress as process 852
2019-07-21T15:47:22.776787Z 5 [Warning] [MY-010453] [Server] root@localhost is created with an empty password ! Please consider switching off the --initialize-insecure option.
2019-07-21T15:47:57.009416Z 0 [System] [MY-013170] [Server] D:\spaces\mysql_8.0.12\bin\mysqld.exe (mysqld 8.0.12) initializing of server has completed
注:如果选择临时密码,上面输出的第二行会有临时密码提示(temporary password is generated for root@localhost: ‘密码’),然后你要记住,当然你如果不想记住也可以,只是要去日志文件中找
2.5、安装Windows服务
serviceName为服务名,不输入默认为mysql
mysqld --install [serviceName]
成功会提示:Service successfully installed.
2.6、启动mysql服务
net start mysql
关闭命令
命令操作步骤net stop mysql
2.7、设置密码
因为一开始使用的是空密码,所以直接在命令行中输入:mysql -u root -p
并回车打开MySQL。
设置自己中意的密码命令:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'zm@root';
2.8、附
总的来说,MySQL压缩包安装还是比较简单的。可能有些小伙伴在安装的时候会出现报错,请先确认安装前是否以前安装的MySQL服务清除了。如果之前有安装过其他版本的mysql服务,那么需要先进行服务卸载。管理员模式进入cmd命令行,然后输入删除mysql服务命令:sc delete mysql
科普一下sc
命令:
描述:
SC 是用来与服务控制管理器和服务进行通信
的命令行程序。
用法:
sc <server> [command] [service name] <option1> <option2>...
<server> 选项的格式为 "\\ServerName"
可通过键入以下命令获取有关命令的更多帮助: "sc [command]"
命令:
query-----------查询服务的状态,
或枚举服务类型的状态。
queryex---------查询服务的扩展状态,
或枚举服务类型的状态。
start-----------启动服务。
pause-----------向服务发送 PAUSE 控制请求。
interrogate-----向服务发送 INTERROGATE 控制请求。
continue--------向服务发送 CONTINUE 控制请求。
stop------------向服务发送 STOP 请求。
config----------更改服务的配置(永久)。
description-----更改服务的描述。
failure---------更改失败时服务执行的操作。
failureflag-----更改服务的失败操作标志。
sidtype---------更改服务的服务 SID 类型。
privs-----------更改服务的所需特权。
managedaccount--更改服务以将服务帐户密码
标记为由 LSA 管理。
qc--------------查询服务的配置信息。
qdescription----查询服务的描述。
qfailure--------查询失败时服务执行的操作。
qfailureflag----查询服务的失败操作标志。
qsidtype--------查询服务的服务 SID 类型。
qprivs----------查询服务的所需特权。
qtriggerinfo----查询服务的触发器参数。
qpreferrednode--查询服务的首选 NUMA 节点。
qmanagedaccount-查询服务是否将帐户
与 LSA 管理的密码结合使用。
qprotection-----查询服务的进程保护级别。
quserservice----查询用户服务模板的本地实例。
delete ----------(从注册表中)删除服务。
create----------创建服务(并将其添加到注册表中)。
control---------向服务发送控制。
sdshow----------显示服务的安全描述符。
sdset-----------设置服务的安全描述符。
showsid---------显示与任意名称对应的服务 SID 字符串。
triggerinfo-----配置服务的触发器参数。
preferrednode---设置服务的首选 NUMA 节点。
GetDisplayName--获取服务的 DisplayName。
GetKeyName------获取服务的 ServiceKeyName。
EnumDepend------枚举服务依赖关系。
以下命令不需要服务名称:
sc <server> <command> <option>
boot------------(ok | bad)指示是否应将上一次启动另存为
最近一次已知的正确启动配置
Lock------------锁定服务数据库
QueryLock-------查询 SCManager 数据库的 LockStatus
示例:
sc start MyService
QUERY 和 QUERYEX 选项:
如果查询命令带服务名称,将返回
该服务的状态。其他选项不适合这种
情况。如果查询命令不带参数或
带下列选项之一,将枚举此服务。
type= 要枚举的服务的类型(driver, service, userservice, all)
(默认 = service)
state= 要枚举的服务的状态 (inactive, all)
(默认 = active)
bufsize= 枚举缓冲区的大小(以字节计)
(默认 = 4096)
ri= 开始枚举的恢复索引号
(默认 = 0)
group= 要枚举的服务组
(默认 = all groups)
语法示例
sc query - 枚举活动服务和驱动程序的状态
sc query eventlog - 显示 eventlog 服务的状态
sc queryex eventlog - 显示 eventlog 服务的扩展状态
sc query type= driver - 仅枚举活动驱动程序
sc query type= service - 仅枚举 Win32 服务
sc query state= all - 枚举所有服务和驱动程序
sc query bufsize= 50 - 枚举缓冲区为 50 字节
sc query ri= 14 - 枚举时恢复索引 = 14
sc queryex group= "" - 枚举不在组内的活动服务
sc query type= interact - 枚举所有不活动服务
sc query type= driver group= NDIS - 枚举所有 NDIS 驱动程序
2、MySQL安装操作
讲完了安装,顺便也讲讲卸载删除。我们的解压版MySQL卸载其实很简单,只要把mysql的服务停掉net stop mysql
,然后将mysql解压文件夹下的data目录删掉就可以了
附上几张Navicat使用图
Navicat启动界面 创建MySQL连接 最新版
网友评论