【MySQL学习】道士下山——MySQL的安装教程

news2024/9/30 7:25:49

  学习数据库,不仅仅需要学习数据库的理论知识,还需要掌握一定的数据库开发能力;为后续的数据库应用开发、数据库内核开发等打下良好的基础。

对于学习者而言,目前市面上的Oracle等数据库软件需要付费,而MySQL作为一款免费数据库软件,可以帮助我们学习MySQL的基本知识及轻松使用MySQL数据库。

一、Windows下MySQL的下载及安装

1.1 MySQL的下载与安装

  MySQL是一款完全免费的关系型数据库系统,其下载地址为:MySQL官网

image-20230218171506724

此外,下载的时候,需要注意尽量下载8.0大类的版本:

image-20230218172216832

下载好的安装包:

image-20230218172358348

双击安装包,按以下步骤进行安装:

image-20230218180000786

根据需求,选择用户自定义安装

image-20230218172921878

若搭配navicat,则选择Server only模式安装

image-20230218173530271

执行安装

image-20230218173636735

image-20230218173741447

image-20230218173845384

image-20230218173929040

image-20230218173958604

设置好密码并牢记,忘记了很麻烦!

image-20230218174124420

设置服务器名称

image-20230218174209018

image-20230218174305797

image-20230218174337262

image-20230218174454391

启动服务器

image-20230218174728486

1.2 Navicat的下载与安装

  Navicat是一款多连接数据库的开发工具,图形化界面方便操作。建议安装正版的Navicat 。学生可以直接教育优惠(教育邮箱验证后免费),具体安装步骤如下:

  双击安装包,一路next

image-20230218183341767

image-20230218183409178

image-20230218183601904

image-20230218183805292

image-20230218183826391

配置环境变量

1.3 MySQL与Navicat连接

image-20230218185544522

image-20230218185758028

image-20230218185733342

二、Linux环境下安装MySQL

  建议在root用户下安装及卸载MySQL,这样普通用户也能使用。对于初学者而言,前期学习时mysql不进行用户管理,使用root运行,以便于快速适应MySQL语句,后续学会了用户管理,再考虑新建普通用户。

2.1 卸载不需要的环境

  注意本文Linux系统为CentOS7,先检查Linux中是否存在MySQL数据库(或mariadb数据库),

image-20230626003121609

关闭

2.2 检查系统安装包

  通过下图的两条指令分别检查系统中mariadb和mysql的安装包:

image-20230809102457887

由上图可知,系统中未发现mysql的安装包。

2.3 卸载默认安装包及获取mysql官方yum源

  接下来,需要卸载mariadbmysql安装包,由于mysql安装包是空的,不需要再卸载。

image-20230809102738799

yum remove mariadb适用于root用户,sudo yum remove mariadb适用于普通用户。

image-20230809103446700

上图中cat /etc/redhat_release指令查看系统的版本。

  获取mysql官方yum源,需要结合Index of /232905 (mysql.com)网站查看当前系统对应的版本:

image-20230626005234047

2.4 安装mysql yum源

  yum -y install lrzsz 命令来安装rz,以便于windows 向centos服务器上传文件。

image-20230626005701993

查看完整是否成功

image-20230626005846061

rpm -Uvh mysql57-community-release-el7.rpm指令安装mysql yum源,会遇到下图的令牌故障:

image-20230626011651260

对于上图报错,使用下指令:

rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022

接着使用yum install -y mysql-community-server重新安装!

最后,通过下图指令检验安装是否成功

image-20230626012009823

2.5 检查能否正常工作及安装mysql服务

image-20230809104429529

  sudo install -y mysql-community-server指令来安装下图所示的公共模块客户端服务器

image-20230809104711534

但上图出现了安装未成功的密钥故障,使用rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022指令来解决密钥过期问题,并重新安装:

image-20230809105556981

2.6 查看配置文件和数据存储位置

image-20230809110433308

2.7 启动服务及及查看服务

启动服务

image-20230809111147192

查看服务

image-20230626012155272

2.8 登录方式的设置

  本文主要介绍无登录密码模式,直接在mysql配置文件中添加skip-grant-tables命令,保存后退出,详见下图:

image-20230809111716200

关于MySQL的语法学习可以参考其语言规范SQL样式指南。此外关于本文图片中华为云服务器和腾讯云服务器的混用,不影响结果,主要因为作者购买的华为云服务器为海外节点,连接速度较慢,因而后续使用腾讯云轻量云服务器。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/852595.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

又一关键系统上线!海底捞进销存系统登陆OceanBase,数据库整体成本节省50%

2020 年,海底捞全面实现“云上捞”,将所有核心业务系统上云,全面推进企业数字化进程。而随着海底捞业务的不断增长,加上数智化转型构建全新的线上智慧服务,原有 IT 系统架构已经逐渐无法有效“驾驭”海量数据与突发流量…

Java之多线程和并发应用

多线程和并发应用 1. 概念与意义2. 多线程的实际应用场景2.1 网络通信2.2 数据库操作2.3 图片处理 3. 多线程的创建方式3.1 继承 Thread 类3.2 实现 Runnable 类3.3 实现 Callable 接口3.4 比较 Thread 和 Runnable3.5 线程同步与锁3.6 线程池 4. 并发编程的挑战和解决方案4.1 …

mysql存储过程定时调度

假设我们要创建一个简单的数据库,其中包含两张表:students 表和 courses 表,以及一个存储过程用于插入学生数据。下面是完整的建表语句、插入语句和存储过程: 1】建表 -- 创建 courses 表 CREATE TABLE courses (course_id INT …

【自然语言处理】大模型高效微调:PEFT 使用案例

文章目录 一、PEFT介绍二、PEFT 使用2.1 PeftConfig2.2 PeftModel2.3 保存和加载模型 三、PEFT支持任务3.1 Models support matrix3.1.1 Causal Language Modeling3.1.2 Conditional Generation3.1.3 Sequence Classification3.1.4 Token Classification3.1.5 Text-to-Image Ge…

OpenLayers入门,OpenLayers涂鸦手绘线条、圆形和多边形,涂鸦线条自动收尾连接成多边形

专栏目录: OpenLayers入门教程汇总目录 前言 本章再次讲解OpenLayers绘制图形功能,上一章中《OpenLayers图形绘制,OpenLayers实现在地图上绘制线段、圆形和多边形》我们已经讲过多种图形的绘制,本章主要讲解自由涂鸦手绘绘制线条,圆形和任意形状。 二、依赖和使用 &q…

Spring BeanPostProcessor 接口的作用和使用

BeanPostProcessor 接口是 Spring 框架中的一个扩展接口,用于在 Spring 容器实例化、配置和初始化 bean 的过程中提供自定义的扩展点。通过实现这个接口,您可以在 bean 实例创建的不同生命周期阶段插入自己的逻辑,从而实现对 bean 行为的定制…

微仓助力制造业数字化转型,实现高效智能供应链!

随着制造业数字化转型的浪潮迅猛涌现,为了应对日益复杂和快速变化的市场需求,制造企业面临着提高生产效率、降低成本、实现供应链高效运作的挑战。在这个数字化时代,微仓作为智能仓储解决方案,正发挥着关键的作用,成为…

verity cannot ... ‘/dev/block/dm-4‘ is read-only/ 证书cacerts系统目录

网上的说的一种做法是 su mount -o rw,remount / mount -o rw,remount /system cp /data/misc/user/0/cacerts-added/269953fb.0 /system/etc/security/cacerts/ rm /data/misc/user/0/cacerts-added/269953fb.0 reboot 但是我机子是android 12.0 提示 /dev/block/dm-4…

NKD:容器云集群与 OS 一体化运维利器

NKD 是 NestOS-kubernetes-Deployer 的缩写,是为了基于 NestOS 部署的 Kubernetes 集群运维工作准备的解决方案。其目标是在集群外提供对集群基础设施(包括操作系统和 Kubernetes 基础组件)的部署、更新和配置管理等服务。 1. 引言 Kuberne…

双栏排版中,[!b]等等的一些命令都不行啊

\usepackage{stfloats} Latex:图片、表格占据双栏排版的两栏时 的位置控制_latex stfloats_weixin_39450145的博客-CSDN博客目录1.问题:怎么在双栏排版中,让占据两栏的表格出现在页面顶端?2.解决:1)图片&a…

378. 有序矩阵中第 K 小的元素

378. 有序矩阵中第 K 小的元素 原题链接:完成情况:解题思路:参考代码:__378有序矩阵中第K小的元素__直接排序__378有序矩阵中第K小的元素__归并排序__378有序矩阵中第K小的元素__二分查找 原题链接: 378. 有序矩阵中…

中学高级本习集c++

第一章 回溯法 1.1 马拦过河卒 源程序名 knight.???(pas, c, cpp) 可执行文件名 knight.exe 输入文件名 knight.in 输出文件名 knight.out 【问题描述】 棋盘上A点有一个过河卒,需要走到目标B点…

山西电力市场日前价格预测【2023-08-10】

日前价格预测 预测明日(2023-08-10)山西电力市场全天平均日前电价为328.01元/MWh。其中,最高日前电价为366.62元/MWh,预计出现在20: 00。最低日前电价为283.28元/MWh,预计出现在13: 15。 价差方向预测 1: 实…

本质安全设备标准(IEC60079-11)的理解(六)温度

本质安全设备标准(IEC60079-11)的理解(六)温度 本质安全设备的温度要求也是非常复杂的,首先在标准中涉及有3个温度的概念: 环境温度ambient temperature, 工作温度service temperature和最高表…

聊聊机器人学习中的“资产”与“负债”(节选)

前言: 程序里面的bug,人生过程的bug,都非常让人烦躁的。 前一篇: 聊聊机器人学习中的“投资”与“消费”(节选) 有很多学生和朋友,越学越累,越活越累?这到底是为何&a…

Java | 包和内部类

目录 一、Java类包 1.1 类名冲突 1.2 完整的类路径 1.3 创建包 1.4 导入包 1.4.1 使用import关键字导入包 1.4.2 使用import导入静态成员 二、内部类 2.1 成员内部类 2.1.1 成员内部类简介 2.1.2 使用this关键字获取内部类与外部类的引用 2.2 匿名内部类 类除了具有…

无涯教程-Perl - getnetbyname函数

描述 此函数返回由NAME指定的网络信息(在列表context中)($name,$aliases,$addrtype,$net) 语法 以下是此函数的简单语法- getnetbyname NAME返回值 此函数在错误时返回undef,否则在标量context中返回网络地址,在错误时返回空列表,否则在列表context中返回网络记录(名称,别…

在软件测试中,如何有效地跟踪和管理缺陷?

在软件测试中,跟踪和管理缺陷是非常重要的,因为这有助于确保所有问题得到妥善处理,避免在产品发布后出现问题。以下是跟踪和管理缺陷的一些有效方法: 1.创建缺陷报告:当发现一个缺陷时,应该立即创建一个缺…

前端进阶js02----null和undefined的区别

1.相同点 1)都是原始类型的值且保存在栈中。 2) 在布尔运算中都会被认为是false 2.不同点 1)null是js的关键字,表示空值;undefined不是关键字,是一个全局变量。 2)值相同,但类型不一样 值相同&#xff1a…

Day 25 C++ queue 容器(队列)

文章目录 queue 基本概念定义注意基本概念队头(Front)——指向队列中最早添加的元素的位置。队尾(Rear)——指向队列中最后添加的元素的位置。入队(Enqueue)——将元素添加到队尾。出队(Dequeue…