MySQL 5.7.29详细下载安装配置教程winx64

article/2025/1/2 4:16:38

https://blog.csdn.net/liu_dong_mei_mei/article/details/104010567

前言

在安装MySQL的时候会遇到很多问题,博客上有很多解决问题的办法,在这里我附上一些链接,遇到问题的朋友们可以阅读参考哈~本文主要针对于刚接触数据库的小白,来安装MySQL数据库。目前官网上的MySQL版本有5.5,5.6,5.7和8,在开发的时候我们一般要选择比最新版低1到2个版本的,因此我选择了5.7作为要安装的数据库

1.下载步骤

Created with Raphaël 2.3.0 开始 访问:https://www.mysql.com/ 点击DEVELOPER ZONE MySQL Downloads MySQL Community Server(或者MySQL Installer for Windows) Looking for the latest GA version? 选择适当的版本进行下载 结束

2.配置环境变量

  1. 系统—>高级系统设置—>环境变量—>系统变量
  2. 点击新建,变量名为:MYSQL_HOME: E:\Program Files\Mysql\mysql-5.7.29-winx64
  3. 解压后mysql-5.7.29-winx64文件夹所在位置。
  4. 编辑Path,添加 ;%MYSQL_HOME%\bin

3.配置my.ini文件

mysql-5.7.27-winx64目录下新建my.ini文件

[mysqld]
#端口号
port = 3306
#mysql-5.7.27-winx64的路径
basedir=E:\Program Files\Mysql\mysql-5.7.27-winx64
#mysql-5.7.27-winx64的路径+\data
datadir=E:\Program Files\Mysql\mysql-5.7.27-winx64\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 

4.安装MySQL

  1. 以管理员的身份运行CMD命令行窗口
  2. 进入.\Mysql\mysql-5.7.27-winx64\bin目录下
  3. 输入mysqld -install
    Service successfully installed,证明安装成功
    Install of the Service Denied,则说明没有以管理员权限来运行cmd
  4. 输入命令:mysqld --initialize
    如果下面的错,修改my.ini 的路径中的单反斜线改为双反斜线
    在这里插入图片描述
    再输入 net start mysql提示启动服务成功。

5.设置MySQL密码

  1. 主要解决ERROR 1045 (28000): Access denied for user ‘root’@‘localhost’ (using password: NO)的问题
  2. 停止MySQL服务,输入命令行net stop mysql
  3. \mysql-5.7.27-winx64目录下找到my.ini,在[mysqld]字段下任意一行添加skip-grant-tables
  4. 重启MySQL,输入启动命令:net start mysql,出现以下提示证明MySQL启动成功
  5. 再输入命令mysql -u root -p,不需要输入密码,直接回车
  6. update user set authentication_string=password("xxxxxx") where user="root";xxxxxx是你设置的新密码,敲击回车后若出现以下信息,证明修改成功!
  7. 手动停止MySQL服务,在win10搜索栏内输入 services.msc ,找到MySQL。点击右键,然后点击停止即可。然后在刚刚的my.ini文件中删除skip-grant-tables这一行,保存关闭。
  8. 再次启动cmd(管理员身份),输入启动命令:net start mysql,再输入mysql -u root -p,再输入你刚刚设置的密码,出现以下信息证明设置成功!
  9. 然后输入命令行use mysql验证一下,结果报错:既然没有重置密码,那就重置一下呗
    键入命令行alter user user() identified by "xxxxxx";我的密码是123456,因此我键入 alter user user() identified by "123456";回车!
  10. 再次输入命令行use mysql验证一下,成功!

mysql中skip-grant-tables无效

1.以管理员的身份打开cmd,关掉MySQL服务:net stop mysql
2.在mysql bin目录下输入:mysqld --skip-grant-tables
3.再打开一个cmd窗口,输入mysql -u root -p
4.输入:use mysql
5.在输入:update user set authentication_string=password("123456") where user="root";
6.cmd:exit
7.cmd:net start mysql
8.cmd:use mysql若报错,alter user user() identified by "123456";再次输入use mysql

mysql服务的启动和停止

net stop mysql
net start mysql

登陆mysql

#注意,如果是连接到另外的机器上,则需要加入一个参数-h机器IP
mysql -u 用户名 -p 用户密码

增加新用户


grant 权限 on 数据库.* to 用户名@登录主机 identified by "密码"
#增加一个用户user1密码为password1,让其可以在本机上登录, 并对所有数据库有查询、插入、修改、删除的权限。首先用以root用户连入mysql,然后键入以下命令:
grant select,insert,update,delete on *.* to user1@localhost Identified by "password1";
#如果希望该用户能够在任何机器上登陆mysql,则将localhost改为"%"。如果你不想user1有密码,可以再打一个命令将密码去掉。
grant select,insert,update,delete on mydb.* to user1@localhost identified by "";

操作mysql数据库

#显示数据库列表
show databases;
#显示库中的数据表
use mysql;
show tables;
#显示数据表的结构
describe 表名;
#建库和删库
create database 库名;
drop database 库名;
#建表:
use 库名;
create table 表名(字段列表);
drop table 表名;
#清空表中记录:
delete from 表名;
#显示表中的记录:
select * from 表名;

第五招、导出和导入数据

#导出数据,将数据库test数据库导出到mysql.test文件,后者是一个文本文件
mysqldump --opt test > mysql.test
#就是把数据库dbname导出到文件mysql.dbname中
mysqldump -u root -p123456 --databases dbname > mysql.dbname
#导入数据:
mysqlimport -u root -p123456 < mysql.dbname。
#文本数据导入数据库,文本数据的字段数据之间用tab键隔开。
use test;
load data local infile "文件名" into table 表名;
#使用SHOW语句找出在服务器上当前存在什么数据库:
SHOW DATABASES;
#创建一个数据库MYSQLDATA
CREATE DATABASE MYSQLDATA;
#选择创建的数据库 按回车键出现Database changed 时说明操作成功!
USE MYSQLDATA; 
#查看数据库中的表
SHOW TABLES;
#创建数据库表
CREATE TABLE MYTABLE (name VARCHAR(20), sex CHAR(1));
#显示表的结构:
DESCRIBE MYTABLE;
#往表中加入记录
insert into MYTABLE values ("hyq","M");
#用文本方式将数据装入数据库表中(例如D:/mysql.txt)
LOAD DATA LOCAL INFILE "D:/mysql.txt" INTO TABLE MYTABLE;
#导入.sql文件命令(例如D:/mysql.sql)
use database;
source d:/mysql.sql;
#删除表
drop TABLE MYTABLE;
#清空表
delete from MYTABLE;
#更新表中数据
update MYTABLE set sex="f" where name='hyq';

windows下mysql数据库导入导出

导出数据库:
1、windows下cmd打开命令行
2、cd 到MySQL的安装目录的bin 目录,如果bin目录添加到环境变量中不需要切换到bin目录
3、导出数据库:mysqldump -u 用户名 -p 数据库名 > 导出的文件名
比如在命令行中输入命令 mysqldump -u root -p person >d:\person.sql (输入后会让你输入进入MySQL的密码)
(如果导出单张表的话在数据库名后面输入表名即可)
4、执行完成后,会看到d盘中有person.sql 文件

导入数据库:
1、进入MySQL:mysql -u 用户名 -p
如我输入的命令行:mysql -u root -p (输入同样后会让你输入MySQL的密码)
2、新建一个数据库,这时是空数据库,如新建一个名为person的目标数据库
3,输入:mysql>use 目标数据库名
如我输入的命令行:mysql>use person;
4,导入文件:mysql>source 导入的文件名;
如我输入的命令行:mysql>source d:/person.sql;

centos中mysql安装、配置、导入数据库

Mysql5.7.11安装 - yum方式:

1、mysql官方网站下载mysql yum repo文件(rpm文件),安装后在系统/etc/yum.repo.d目录多出2个文件
2、yum search mysql
3、yum install mysql-community-server.x86_64 (mysql社区版)

新安装mysql后无root密码无法登陆问题:
1.systemctl stop mysqld.service 关闭mysql服务
2.vi /etc/my.cnf 在mysqld下面添加 skip-grant-tables,重启mysql服务systemctl start mysqld.service
3.登录mysql,mysql -u root 不用密码直接回车
4.输入 update user set authentication_string=password('密码') where User='root' and Host='localhost';
5.成功后输入 flush privileges;
6.exit退出mysql
7.vi /etc/my.cnfskip-grant-tables 一句删除保存退出重启mysql服务
8.重新登录mysql,mysql -u root -p回车 输入你刚才填写的密码
9.登录成功后你的操作可能会出现如下两句

Your password does not satisfy the current policy requirements
You must reset your password using ALTER USER statement before executing this statement.

进入mysql执行命令:

alter user 'root'@'localhost' identified by 'password'
=====================
Show databases;
Create dbname;
Use dbname;
Set names utf8;
Mysql -u root -p dbname<script.sql;

本地sql文件导入mysql数据库

mysql中配置my.ini

interactive_timeout = 120
wait_timeout = 120
max_allowed_packet = 32M      

导入sql运行命令

source    "路径名"+/mytest.sql

进入对应的数据库,example: test

use  test;
source    C:/Users/eason\Desktop/mytest.sql

在这里插入图片描述
当我用Navicat查看用户表的时候,发现乱码。
排查:
1、my.ini中设置默认编码格式utf-8
2、导入库是设置支持utf-8
3、命令行登录数据库需要支持utf-8
在这里插入图片描述

可以查看用户表,是否中文。

使用navicat导入sql文件

一、打开navicat,打开连接,右击连接名(如果新建连接,需要使用对应数据库的ip地址和密码,本机的是地址localhost,密码是自己mysql数据库的密码),选择新建数据库,数据库名要和想要导入的文件名一样(这种情况针对的是sql文件是直接由整个数据库导出的一个sql文件,如果表导出的sql文件,应该是随便命名数据库的名字,表名应该是和需要导入的文件名字相同(第二种情况没有亲自试过))。

在这里插入图片描述

二、右击建好的数据库,选择运行SQL文件,在出现的页面中选择要导入的SQL文件。然后点击开始,等待导入结束。
在这里插入图片描述
在这里插入图片描述

三、在导入结束后,点击关闭,此时可能数据库中还没有导入的表,右击数据库名字或者表选择刷新,应该就出来了。(最后记不太清是右击哪个,点击刷新,试一下一般就可以出来了,亲测有效)。之后又试了一次是右击表的名字,点击刷新。
在这里插入图片描述
Navicat for Mysql 是应用比较多的mysql的视图管理工具。下面记录下Navicat for mysql如何导入sql文件。

首先创建一个数据库(因为我导入的sql文件只有建表和插入数据的语句)。

在连接名处点击右键,新建数据库。

1565317402(1).png

输入数据库的名称,这里我选择utf-8编码,因为我安装的mysql时有特意选择utf-8。

1565317418(1).png

相关推荐:《Navicat for mysql使用图文教程》

双击你新建的数据库,使之显示绿色状态。然后在该数据库的名称上面点击右键,选择运行sql文件。

1565317430(1).png

然后点击如图所示的图标来查找你要运行的sql文件。

1565317442(1).png

注意当你要运行的sql文件有多个的时候,一定要注意它们的先后顺序。比如先有建表的sql,才有插入数据的sql。

1565317456(1).png

选中之后,点击确定,它就会运行sql语句。如果成功,会有如下相关的信息显示,然后点击关闭。

1565317469(1).png

此时点击你的运行sql文件的数据库,然后F5刷新,就能看到sql的效果了(比如有表结构和数据)。

1565317489(1).png

查看修改mysql编码方式让它支持中文(gbk或者utf8)

MySQL的默认编码是Latin1,不支持中文,要支持中文需要把数据库的默认编码修改为gbk或者utf8。

1、需要以root用户身份登陆才可以查看数据库编码方式(以root用户身份登陆的命令为:>mysql -u root –p,之后两次输入root用户的密码),查看数据库的编码方式命令为:

>show variables like 'character%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | latin1 |
| character_set_connection | latin1 |
| character_set_database | latin1 |
| character_set_filesystem | binary |
| character_set_results | latin1 |
| character_set_server | latin1 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+

从以上信息可知数据库的编码为latin1,需要修改为gbk或者是utf8;
其中,character_set_client为客户端编码方式;
character_set_connection为建立连接使用的编码;
character_set_database数据库的编码;
character_set_results结果集的编码;
character_set_server数据库服务器的编码;
只要保证以上四个采用的编码方式一样,就不会出现乱码问题。
另一个查看数据库编码的命令:

>show variables like ‘collation%';

2、linux系统下,修改MySQL数据库默认编码的步骤为:
ü 停止MySQL的运行
/etc/init.d/mysql start (stop) 为启动和停止服务器
ü MySQL主配置文件为my.cnf,一般目录为/etc/mysql
var/lib/mysql/ 放置的是数据库表文件夹,这里的mysql相当于windows下mysql的date文件夹
ü 当我们需要修改MySQL数据库的默认编码时,需要编辑my.cnf文件进行编码修改,在linux下修改mysql的配置文件my.cnf,文件位置默认/etc/my.cnf文件

找到客户端配置[client] 在下面添加
default-character-set=utf8 默认字符集为utf8
在找到[mysqld] 添加
default-character-set=utf8 默认字符集为utf8
init_connect=‘SET NAMES utf8’ (设定连接mysql数据库时使用utf8编码,以让mysql数据库为utf8运行)

修改好后,重新启动mysql 即可,重新查询数据库编码可发现编码方式的改变:

>show variables like 'character%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+

此方法用于标准mysql版本同样有效,对于/etc/my.cnf文件,需要从mysql/support-files的文件夹cp my-large.cnf一份到/etc/my.cnf

3、windows系统下可以删除MySQL数据库,并重新安装,在安装过程中可以直接用Mysql Server Instance Config Wizard 进行设置

4、当MySQL数据库服务器已经有数据不适合删除重装时,可以个别指定数据库的编码方式。MySQL指定编码的方式是非常灵活并多样化的,可以指定表级别的编码,行级别编码,甚至可以指定字段级别的编码。
以下示例给出创建数据库时指定编码的两种方式:
1)CREATE DATABASE ms_db CHARACTER SET utf8 COLLATE utf8_general_ci;
2)create database if not exists netctoss default character set utf8;
5、如果你采用的是外部接入的方式,可以在连接中确定请求的编码格式如:jdbc:mysql://localhost:3306 /mysql?useUnicode=true&characterEncoding=utf-8(注意:不要出现任何空格,否则出错)
6、执行脚本:指定编码格式set names gbk(注意,不是UTF-8)可以修改
执行前:
执行后:
从执行命令前后可知,set names gbk只可以修改character_set_client、character_set_connection、 character_set_results的编码方式,并且这种修改是窗口级别的,只针对本窗口有效,打开另外一个窗口修改无效。也可发现数据库底层的编码方式没有改变,插入数据后还是以utf8编码方式保持。


http://chatgpt.dhexx.cn/article/ekqtlNXE.shtml

相关文章

NAND FLASH MT29F4G08

1 简介 我们通过stm32f429的fmc接口实现对MT29F4G08的访问&#xff0c;实现读写数据功能 NAND FLASH信号线 NAND FLASH 框图 NAND FLASH 存储阵列 以上可以得知&#xff1a;(MT29F4G08) 每个这样的芯片有两个plane 每个plane有2048个block&#xff0c;一个包含偶数块&am…

Unity开发 罗技方向盘 G29 白话版

Unity开发罗技方向盘 白话版 目录前言准备工作测试阶段运行失败的解决 接入UnityDemo的使用方法接入自己的项目 问题与总结问题总结 目录 前言 最近在做罗技G29的方向盘的Unity开发&#xff0c;因为设备很贵(2000)所以在买之前先进行了一波调研&#xff0c;看看用Unity开发的…

如何解决version `GLIBCXX_3.4.29‘ not found的问题

首先&#xff0c;运行时出现的问题如下&#xff1a; ImportError: /lib/x86_64-linux-gnu/libstdc.so.6: version GLIBCXX_3.4.29 not found (required by /home/wuye/anaconda3/envs/tf2/lib/python3.8/site-packages/google/protobuf/pyext/_message.cpython-38-x86_64-linu…

Ubuntu环境下读取罗技G29方向盘信息

Ubuntu环境下读取罗技G29方向盘信息 引言 实验室有这么酷的驾驶设备&#xff0c;来了一年还没有实际操作过&#xff0c;早就蠢蠢欲试了&#xff0c;哈哈哈不过之前负责的师兄还在就一直没敢用&#xff0c;现在他毕业了就可以为所欲为了 之前师兄好像都是在Windows下开发的&…

UDS 安全认证29服务概述

一&#xff0e;服务概述 此服务的目的是为客户提供一种证明其身份的方法&#xff0c;允许其访问数据和/或诊断服务&#xff0c;这些数据和/或诊断服务由于安全、排放或安全等原因而受到限制。 用于将例程或数据下载/上传到服务器以及从服务器读取特定内存位置的诊断服务可能需…

SQLi LABS Less-29

第29关使用GET请求提交参数,在url中构造payload即可 源码中并没有做什么过滤,直接测试注入点即可 在url中输入 1and true-- a,源码中的SQL会拼接成下面这样 注释后面的内容不起作用,所以真正执行的SQL是这样的 and后面的true会使SQL恒成立,SQL正常查询出用户内容,并在页面显示…

AE 提示29:0

报错信息说明&#xff1a; After Effects error警告&#xff1a;内部验证失败。该project工程项目的内部秩序混乱。 报错的可能原因&#xff1a; 当在Project项目窗口中替换素材&#xff0c;或重命名素材时&#xff0c;有些引用的数据被破坏了。建议解决方法&#xff1a; 将工程…

UN ECE WP.29 R155 R156 概述

目录 1. 什么是UNECE WP.29 2. WP.29合规认证要求 3. WP.29和ISO/SAE 21434之间的关系 4. WP.29 R155 - Cybersecurity 5. WP.29 R156 - Software Update 1. 什么是UNECE WP.29 UNECE: The United Nations Economic Commision for Europe , 联合国欧洲经济委员会。创建于1…

认识UDS诊断29认证服务-Authentication Service

目录 1.概述 2. 背景知识 3. 服务介绍 4. 服务实现 5. 与27服务的比较 1.概述 29服务是在ISO 14229-2020版本中首次增加的为应对网联汽车日益增加的安全风险的新服务。 此服务的目的顾名思义是为client和server之间的身份认证提供一种方法&#xff0c;以便对意图获取一些…

UDS 29服务

目录 一、29服务支持安全概念 二、基于APCE的认证&#xff08;KPI&#xff09; 三、基于ACR认证 一、29服务支持安全概念 1、APCE&#xff1a;采用非对称加密的基于PKI证书交换程序的认证 2、ACR&#xff1a;采用对称或非对称加密的基于挑战确认流程的认证 子功能介绍&am…

常用三种正态检验方法

带正态曲线直方图 利用SPSS的菜单分析环境&#xff1a;“分析”-“描述统计”-“频率”&#xff0c;在绘图选项选择带正态曲线的直方图。 绘制带正态曲线的直方图通过对比直方图与正态曲线的拟合程度&#xff0c;判定数据序列的分布形态是否接近正态分布。下面两幅图是某班级…

Origin_正态检验以及频率统计

文章目录 正态检验1、导入数据2、进行正态检验 频率统计1、选中数据2、执行频率统计 正态检验 1、导入数据 将该列填充以100为中心的随机整数 2、进行正态检验 突出显示A列&#xff0c;然后单击“Statistics: Descriptive Statistics: Normality Test”以打开对话框。所选…

past软件_Past软件与AndersonDarling正态性检验

如欲转载本文,请先与作者联系并获得授权。 本文由正在制作中的新教程修改而来。 目录 1 Past软件下载 2 A-D检验简介 3 操作 4 参考文献 1 Past软件下载 读者可在本公众号(邱宗满)内通过下方菜单“资料课程→软件下载→数据分析软件”下载该软件,也可以在Past软件官网进行下载…

正态性检验ks和sw区别_t检验常见问题汇总解答,你想知道的都在这里

在分析过程中,无论是由于数据质量还是统计方法选择上,甚至是自己也讲不清的什么原因都可能导致数据无法正常分析。这种细节的问题,文献里一般又不会详细说明,而实际分析时遇见一次就非常头疼。 因此,SPSSAU汇总了一些常用方法中出现频率较高的问题,整理成文章,大家可以…

基于spss的正态分布正态性检验

****基于spss的正态分布正态性检验**** 正态分布正态性检验频率直方图实验步骤 P-P图实验步骤 Q-Q图实验步骤 K-S 检验实验步骤 描述法(偏度和峰度系数检验)实验步骤 简要介绍这五种方法&#xff0c; 有需要数据练习的练习我 正态分布 正态分布&#xff08;Normal distribution…

python正态检验_python验证正态分布

验证正态分布 为什么要检验数据的正态性&#xff1f; 很多时候&#xff0c;我们都需要使用从单一样本中获取的样本信息利用统计推断的方法来估计总体的参数信息&#xff0c;这是一种非常有用的统计方法&#xff0c;但在执行相关推断之前&#xff0c;我们需要验证一些假定&…

matlab 数据正态性检验

matlab 数据正态性检验 matlab 数据正态性检验 数据说明描述性图像 指数走势图收益率散点图收益率频率分布直方图Q-Q 图峰度与偏度系数 峰度偏度jb 检验代码下载数据说明 以前推荐用tushare是因为tushare免费,但是现在tushare非常无耻,积分不透明变像收费早已背离初心,建议…

非参数正态性检验

点击上方“小白学视觉”&#xff0c;选择加"星标"或“置顶” 重磅干货&#xff0c;第一时间送达本文转自&#xff1a;机器学习算法那些事 非参数正态性检验 前面两节介绍了采用Q-Q图和偏度与峰度来对采集样本进行正态性检验&#xff0c;本节介绍非参数性的正态性检验…

R语言数据统计1——正态性检验

引用 正态性检验之qqplot和ppplot原理及R语言实现 QQ图 KS检验和SW检验的区别 t检验算法及其在R语言中的实现 R语言做正态分布检验 R语言与统计分析 数据统计中的方差分析第一步应该是检查数据&#xff0c;其次做正态性检验。 而正态性检验&#xff1a; KS检验&#xff08…

正态分布方差检验

卡方检验、F检验 定义 χ 2 \chi^2 χ2 检验123实验设计 F F F 检验123 附录假设检验一般步骤势函数 定义 用于检验总体呈正态分布的方差的假设检验&#xff0c;其中 χ 2 \chi^2 χ2 检验常用于单样本正态方差检验&#xff1b; F F F 检验用于双样本的正态方差检验。 χ 2 \…