Windows系统,自建搭建MySQL8服务器
nanshan 2024-10-31 13:42 21 浏览 0 评论
MySQL安装
- 一、mysql安装包下载
- 二、配置my.ini文件
- 三、初始化MySQL
- 四、可能遇到的错误操作(没出错就可以跳过了)
一、mysql安装包下载
官网下载地址:mysql安装包下载
二、配置my.ini文件
- 解压后的文件尽量不要放在C盘(内存小),解压后如下图所示
- 在上图所示根目录下配置my.ini文件
- 右键创建一个文本(.text)
- 修改命名为my.ini(.ini就是一种文件的格式和text一样的东西)
- 将下面的内容复制到my.ini中(将mysql的安装目录,mysql数据库的数据的存放目录改成你的下载路径和存放路径)
[mysqld]
# 设置3306端口
port=3306
[mysqld]
# 设置3306端口
port=3306
# 设置mysql的安装目录(存放地址要改成你的下载路径)
basedir=C:\MySQL
# 设置mysql数据库的数据的存放目录(存放地址要改成你的下载路径)
datadir=D:\MySQL\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
三、初始化MySQL
- 初始化MySQL,在安装时,避免权限问题出错我们尽量使用管理员身份运行cmd
- 否则在安装时会报错,会导致安装失败的情况,如下图所示:
- 打开软件所在目录
- 地址栏输入cmd即可运行,前提是能够以管理员方式打开
- 安装报错
- 经过一系列尝试,安装成功
- 将以下内容写入bat文件,直接点击运行即可完成安装
@echo off
@REM 转到存储目录
@REM set MYSQL_PATH=C:\Users\WDAGUtilityAccount\Downloads\mysql-8.0.30-winx64\mysql-8.0.30-winx64
@REM cd %MYSQL_PATH%
cd bin
echo %cd%
@REM 初始化MySQL,记录初始化密码
mysqld --initialize --console
@REM 安装MySQL服务,输入 `mysqld --install [服务名]`(服务名可以不加默认为mysql)
mysqld --install
@REM 启动SQL
net start mysql
@REM 输入初始密码(这样子就进入数据库了,可以更改你的密码了)
mysql -uroot -p
@REM 以下是修改密码过程
mysql> ALTER USER USER() IDENTIFIED BY 'abc123456';# abc123456 为密码
mysql> FLUSH PRIVILEGES;
@pause
@REM 停止SQL
@REM net stop mysql
【可以配置环境变量】
四、一些可能用到的操作
首次链接可以使用工具修改初始密码
- 我使用的是HeidiSQL portable版本,在本地运行,使用localhost链接
- 第一次链接,会自动提示更改密码,无难度
不使用密码登录
- 打开两个CMD窗口,以管理员方式
mysqld --console --skip-grant-tables --shared-memory - 另外一个窗口直接不输入密码登录
mysql -uroot -p
修改root密码
ALTER USER 'root'@'localhost' IDENTIFIED BY 'acd123456@';
输入以下三句命令重置root密码为空:
use mysql;
update user set authentication_string='' where user='root';
quit;
创建用户,并授权登录
- 以下是首次安装后,新建用户,授权等操作,均在HeidiSQL portable中操作,对于不喜欢命令的人来说毫无难度
-- 1. 进入mysql
mysql -u root -p
-- 2. 创建用户
create user 'zhangsan'@'%' identified by 'Abc927**';
-- 这里表示创建一个不限制ip登录的用户 zhangsan
-- 该用户的密码是 Abc927**
-- %代表不限制ip登录
flush PRIVILEGES;
-- 刷新权限,每一次权限更改后都刷新一下
-- 3. 给用户赋权
grant all privileges on test_grant.* to 'zhangsan'@'%' with grant OPTION;
-- 这里表示给用户eexcloud赋予数据库test_grant(这是我之前创建好的数据库)中所有表的所有权限
-- with grant option表示该用户可以给其他用户赋权,但是不能超过该用户的权限
-- 此时查看,用户eexcloud多了一个test_grant数据库
-- 这里的all privileges 可换成select,insert,update,delete,drop,create等
-- 实测:赋予eexcloud用户跟root相同的权限
grant all privileges on *.* to 'zhangsan'@'%' with grant OPTION;
-- 记得完成后刷新权限
flush PRIVILEGES;
-- 4. 查看用户权限
show grants for 'zhangsan'@'%';
-- 5. 撤销用户权限
revoke all privileges on test_grant.* from 'zhangsan'@'%';
-- 这里表示撤销用户testuser1对数据库test_grant的所有操作权限
-- 注意:这里如果这么写,你会发现你打开还是有数据库test_grant(不过你无法操作该数据库了),这是因为我之前创建的时候用到了with grant option,因为all privileges 是除了with grant option的所有权限
-- 执行如下语句 回收用户所有权限即可
revoke all privileges,grant option from 'zhangsan'@'%';
-- 6. 删除用户
drop user 'zhangsan'@'%';
-- 7. 查询所有用户及其权限
SELECT DISTINCT CONCAT('User: ''',user,'''@''',host,''';') AS query FROM mysql.user;
-- 也可以这样
SELECT User, Host FROM mysql.user;
五、可能遇到的错误操作(没出错就可以跳过了)
第一种情况
- 解决MySQL初始化报错:
mysqld: Can’t create directory ’xxxx’ (ErrorCode 2 - No such file or directory) - 将my.ini配置文件里的路径盘符后面的单斜杠改为双斜杠就可以了
- 修改前:
[mysqld]
port = 3306
basedir=E:\MySQL
datadir=E:\MySQL\data
- 修改后:
[mysqld]
port = 3306
basedir=E:\\MySQL
datadir=E:\\MySQL\data
- 再执行mysqld --initialize命令会生成data文件夹及相应文件
第二种
mysqld -install命令时出现install/remove of the service denied错误的原因和解决办法
没有以管理员身份启动cmd.exe
【快捷键】:win+r 输入cmd ctrl+shift+enter进入cmd(以管理员方式)
下面图片的是经典操作!!!
第三种
配置my.ini文件后登录有出现utf8字符集出错,将my.ini配置内容改为如下内容
[mysqld]
# 设置mysql的安装目录,也就是刚才我们解压的目录
basedir=E:\MySQL
# 设置mysql数据库的数据的存放目录
# datadir=E:\MySQL\bin
# 设置默认使用的端口
port=3306
# 允许最大连接数
max_connections=200
# 允许连接失败的次数。这是为了防止有人试图攻击数据库
max_connect_errors=10
# 服务端使用的字符集
character-set-server=utf8mb4
# 数据库字符集对应一些排序等规则使用的字符集
collation-server=utf8mb4_general_ci
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
# 默认使用“mysql_native_password”插件作为认证加密方式
# MySQL8.0默认认证加密方式为caching_sha2_password
default_authentication_plugin=mysql_native_password
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8mb4
[client]
default-character-set=utf8mb4
port=3306
第四种
ERROR 1045 (28000): Access denied for user ‘root’@‘localhost’ (using password: YES);
【解决步骤】:
将my.ini的内容换成上一个错误上的内容(即是第三个错误)
删除data文件
重新进行初始化mysqld --initialize --console
登录mysql -uroot -p临时密码
第五种
- 找不到MSVCP140.dll
- 下载vc_redist.x64
- Visual C++ Redistributable Package
- 找不到vcruntime140_1.dll
- 下载最新的vc_redist.x64
- Visual Studio 2015、2017、2019 和 2022
- 安装
相关推荐
- 如何为MySQL服务器和客户机启用SSL?
-
用户想要与MySQL服务器建立一条安全连接时,常常依赖VPN隧道或SSH隧道。不过,获得MySQL连接的另一个办法是,启用MySQL服务器上的SSL封装器(SSLwrapper)。这每一种方法各有其...
- Mysql5.7 出现大量 unauthenticated user
-
线上环境mysql5.7突然出现大量unauthenticateduser,进mysql,showprocesslist;解决办法有:在/etc/hosts中添加客户端ip,如192.16...
- MySQL 在 Windows 系统下的安装(mysql安装教程windows)
-
更多技术文章MySQL在Windows系统下的安装1.下载mysql和Framework链接链接:百度网盘请输入提取码提取码:6w3p双击mysql-installer-communit...
- MySql5.7.21.zip绿色版安装(mysql数据库绿色版安装)
-
1、去网上下载满足系统要求的版本(mysql-5.7.21-winx64.zip)2、直接解压3、mysql的初始化(1)以管理员身份运行cmd,在mysql中的bin目录下shift+右键-在...
- MySQL(8.0)中文全文检索 (亲测有效)
-
在一堆文字中找到含有关键字的应用。当然也可以用以下语句实现:SELECT*FROM<表名>WHERE<字段名>like‘%ABC%’但是它的效率太低,是全盘扫描。...
- 新手教程,Linux系统下MySQL的安装
-
看了两三个教程。终于在哔哩哔哩找到一个简单高效的教程,成功安装,up主名叫bili逍遥bili,感兴趣可以去看看。下面这个是我总结的安装方法环境:CentOS764位1.下载安装包,个人觉得在...
- 麒麟服务器操作系统安装 MySQL 8 实战指南
-
原文连接:「链接」Hello,大家好啊,今天给大家带来一篇麒麟服务器操作系统上安装MySQL8的文章,欢迎大家分享点赞,点个在看和关注吧!MySQL作为主流开源数据库之一,被广泛应用于各种业务...
- 用Python玩转MySQL的全攻略,从环境搭建到项目实战全解析
-
这是一篇关于“MySQL数据库入门实战-Python版”的教程,结合了案例实战分析,帮助初学者快速掌握如何使用Python操作MySQL数据库。一、环境准备1.安装Python访问Pytho...
- 安装MySQL(中标麒麟 安装mysql)
-
安装MySQL注意:一定要用root用户操作如下步骤;先卸载MySQL再安装1.安装包准备(1)查看MySQL是否安装rpm-qa|grepmysql(2)如果安装了MySQL,就先卸载rpm-...
- Mysql最全笔记,快速入门,干货满满,爆肝
-
目录一、MySQL的重要性二、MySQL介绍三、软件的服务架构四、MySQL的安装五、SQL语句六、数据库相关(DDL)七、表相关八、DML相关(表中数据)九、DQL(重点)十、数据完...
- MAC电脑安装MySQL操作步骤(mac安装mysqldb)
-
1、在官网下载MySQL:https://dev.mysql.com/downloads/mysql/根据自己的macOS版本,选择适配的MySQL版本根据自己需求选择相应的安装包,我这里选择macO...
- mysql主从(mysql主从切换)
-
1、本章面试题什么是mysql主从,主从有什么好处什么是读写分离,有什么好处,使用mycat如何实现2、知识点2.1、课程回顾dubboORM->MVC->RPC->SOApro...
- 【linux学习】以MySQL为例,带你了解数据库
-
做运维的小伙伴在日常工作中难免需要接触到数据库,不管是MySQL,mariadb,达梦还是瀚高等其实命令都差不多,下面我就以MySQL为例带大家一起来了解下数据库。有兴趣的小伙伴不妨评论区一起交流下...
- 玩玩WordPress - 环境简介(0)(玩玩网络科技有限公司)
-
简介提到开源博客系统,一般都会直接想到WordPress!WordPress是使用PHP开发的,数据库使用的是MySQL,一般会在Linux上运行,Nginx作为前端。这时候就需要有一套LNMP(Li...
- 服务器常用端口都有哪些?(服务器端使用的端口号范围)
-
下面为大家介绍一下,服务器常用的一些默认端口,以及他们的作用: 21:FTP服务所开放的端口,用于上传、下载文件。 22:SSH端口,用于通过命令行模式远程连接Linux服务器或vps。 23:...
你 发表评论:
欢迎- 一周热门
-
-
极空间如何无损移机,新Z4 Pro又有哪些升级?极空间Z4 Pro深度体验
-
如何在安装前及安装后修改黑群晖的Mac地址和Sn系列号
-
UOS服务器操作系统防火墙设置(uos20关闭防火墙)
-
爱折腾的特斯拉车主必看!手把手教你TESLAMATE的备份和恢复
-
日本海上自卫队的军衔制度(日本海上自卫队的军衔制度是什么)
-
10个免费文件中转服务站,分享文件简单方便,你知道几个?
-
手机如何设置与显示准确时间的详细指南
-
如何修复用户配置文件服务在 WINDOWS 上登录失败的问题
-
【系统配置】信创终端挂载NAS共享全攻略:一步到位!
-
[常用工具] OpenCV_contrib库在windows下编译使用指南
-
- 最近发表
- 标签列表
-
- linux 查询端口号 (58)
- docker映射容器目录到宿主机 (66)
- 杀端口 (60)
- yum更换阿里源 (62)
- internet explorer 增强的安全配置已启用 (65)
- linux自动挂载 (56)
- 禁用selinux (55)
- sysv-rc-conf (69)
- ubuntu防火墙状态查看 (64)
- windows server 2022激活密钥 (56)
- 无法与服务器建立安全连接是什么意思 (74)
- 443/80端口被占用怎么解决 (56)
- ping无法访问目标主机怎么解决 (58)
- fdatasync (59)
- 405 not allowed (56)
- 免备案虚拟主机zxhost (55)
- linux根据pid查看进程 (60)
- dhcp工具 (62)
- mysql 1045 (57)
- 宝塔远程工具 (56)
- ssh服务器拒绝了密码 请再试一次 (56)
- ubuntu卸载docker (56)
- linux查看nginx状态 (63)
- tomcat 乱码 (76)
- 2008r2激活序列号 (65)