数据库入门下篇(如何安装和登录MYSQL数据库)

在这篇文章里,笔者将着重讲解如何在win和Linux系统上安装自己的MySQL数据库软件,以及安装好数据库软件后如何启动和登录,忘了密码怎么办?如何创建一个数据库,如何在数据库中创建一个表等内容

目录

在windows系统上安装MySQL数据库

在Linux下安装MySQL

启动MySQL服务

尝试创建数据库

初识MySQL数据库运行结构


 

在windows系统上安装MySQL数据库

Windows直接在浏览器上搜索并选择相应版本的MySQL下载安装即可

如果你把MySQL数据库文件都放到了D盘,那么你可能无法直接在命令行中使用MySQL启动命令,你需要移动到D盘下MySQL文件下的bin目录下,才能够启动MySQL的服务

例如,我的MySQL文件就放到了D盘中

 

在命令行中,无法在C盘下直接启动,需要移动到D盘的MySQL文件的bin目录下才能启动

这样做很麻烦,因为命令行默认在C盘下,你又不想把MySQL安装到C盘下,那么每次启动MySQL都得移动到相关的路径下,有没有可以就放在D盘中,但又能在命令行中直接启动MySQL的方法呢?有的,这就需要我们修改系统环境变量,做法如下

1.找到你在D盘下存放的MySQL文件的bin目录的绝对路径

 D:\mysql-8.0.28-winx64\mysql-8.0.28-winx64\bin(这是我的bin目录的决定路径)

找到之后复制整个路径,然后在系统设置中搜索环境变量

 

2.打开,在高级栏中找到环境变量,点击,然后进入到环境变量设置页面

找到系统环境变量下的 Path

 3.找到Path后,点击编辑,再点击新建,把你复制的bin目录的绝对路径添加到里面,然后确定,回到桌面刷新

 

 4.再次打开命令行,输入登录命令,你就发现可以直接在C盘路径下启动MySQL文件了

 在Linux下安装MySQL

1.先检查自己的Linux系统是否有残余的曾经未卸载完全的MySQL文件

输入命令: ps ajx |grep mariadb      # 先检查是否有mariadb存在

如果有则输入命令   systemctl stop mariadb.service     # 停⽌mariadb服务

2.检查当前系统下是否有残留的MySQL安装包

输入命令    rpm -qa | grep mysql     #检查是否有残留安装包

如果有则输入命令  sudo yum remove mariadb   #卸载残留的MySQL安装包   

 3.去网址 http://repo.mysql.com/  获取mysql官⽅yum源

注意一定要根据自己的Linux系统选择适合自己的版本,选择合适的版本后将其下载到自己的本地磁盘中,如果你使用的是服务器,那么可以通过Xshell将下载好的文件上传到服务器上

我使用的是服务器,通过Xshell上传后,使用ls命令,能看到上传完成的MySQL的yum源

即:mysql57-community-release-el7-10.noarch.rpm

 4.将下载好的MySQLyum源安装

使用命令:rpm -Uvh mysql57-community-release-el7-10.noarch.rpm  #安装下载好的yum源
这个过程如果出错了,那么请尝试用sudo提权,或者直接用root用户安装

 5.正式开始安装MySQL服务

使用命令:sudo yum install -y mysql-community-server   #安装MySQL服务

安装过程中可能会出现这样的错误

GPG Keys are configured as: file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

这是因为安装密钥过期了,不用担心

使用命令:rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022

这一步是为了更新安装密钥,更新完成后,再次输入安装命令开始安装即可            

启动MySQL服务

下载安装完成后启动MySQL服务    systemctl start mysqld.service

登录进入MySQL,使用命令     mysql -u root -p

mysql:指的是启动mysql服务, -u:指的是用哪个用户登录  root:指的是用root这个用户登录,我们前期练习就用root用户,后面可以再改   -p:指的是提示输入登录密码

如果你是新用户,在输入时,你并不知道密码是什么,那我们直接通过修改配置文件的方式,跳过第一次密码登录,登录成功后,通过修改密码的命令,修改自己的密码,然后在配置文件中去掉跳过密码登录的命令(如果你在日后忘了登录密码也可以这样干)

在Linux下,通过命令:vim /etc/my.cnf       #打开mysql配置⽂件

然后在配置文件末尾加上命令 skip-grant-tables   之后保存退出

重新启动MySQL服务 systemctl restart mysqld

再次登录MySQL时,如果提示输入密码,直接回车跳过即可登录成功

以上是Linux环境下的操作,window的相关的操作有很多的文章讲解,这里就不再说了

尝试创建数据库

 如果你输入了密码,成功来到了如下的界面,那么恭喜你,你已经攻破了新手第一关

我们要使用数据库,在数据库上进行数据的增删查改,那么就得使用一种数据库语言来与数据库进行交流,主流的数据库语言就是SQL语言,基本上关系型数据库都采用SQL语句来作为与数据库沟通的语言。可能说到编程语言,大家心里就一紧,因为学习一门新的编程语言,还是相当耗费精力的

不过请放心,SQL语言严格来说并不是编程语言,而是一种查询语言,因为SQL不具有图灵完备,不像主流的编程语言那样有较强的编程能力,SQL的语法关键字就那几个,主要的目的就是用来对数据进行增删查改的

接下来,我们介绍几个新手常用的命令

show databases(注意在sql语句结束后,要在语句末尾加上;表示语句结束)

当我们刚使用命令mysql -u root -p 登录进入mysql后不知到该干些什么事情时,那么可以用这个命令来查看当前root用户存在哪些数据库,一个用户是可以创建多个数据库的

图中的my_test是笔者自己创建的,剩余的则是系统默认创建的一些数据库,我们暂时不用管系统默认创建的,先使用命令 create database name;   创建一个自己的数据库

注意name是你要创建的数据库的名字,下图是演示部分

那么blog_test这个数据库就被创建好了,接下来就是要使用这个数据库了,那么怎么使用呢?

使用命令 use name( name是数据库的名称)进入到指定的数据库中

当你看到 Database changed,那就说明已经进入到了数据库中

在图中,我们可以看到已经进入到了blog_test这个数据库中,那么 show tables; 这个命令是什么意思呢?还记得在入门上篇提到过吗?MySQL是关系型数据库,那么关系型数据库就是使用二维表来存储数据的,table字面意思就是表格,show tables就是查看当前这个数据库有哪些表, 由于我们没有在这个数据库中建立表格来存储数据,所以结果为空

接下来咱们尝试建立一些表格,并插入一些数据,在上篇文章中,我们提到过,要想存储某些实体的数据,那么首先的抽象出这些实体共有的属性信息。我们以学生为例,学生的属性信息有姓名,学号,性别,当然还有很多其他的属性信息,但是我们目前只需要用到这些

所以接下来我们就用姓名,学号,性别这些属性来创建一张学生二维表

使用命令

create table  students( 姓名 varchar(30), 

学号 varchar(15),

性别 varchar(10) );

这样就能够创建一张学生二维表了,接下来解释一下上面这串命令,students就是要创建的表的表名,姓名 varchar(30) 表示该表的第一个属性列为姓名,用30个char字符来存储

学号 varchar(15) 表示该表的第二个属性列为学号,用15个char字符来存储

性别 varchar(10) 表示该表的第三个属性列为性别,用10个char字符来存储

注意,这几个属性都在 () 里,表示是students这张表的属性,每个属性之间都要用 ',' 分隔开,关于存储数据类型,笔者会在后面文章专门介绍

做完这些,students这张表就正式建立好了

接下来,我们可以使用如下命令,看看表格的形式

desc name

show create table name

(name是指表名)

初识MySQL数据库运行结构

可能大家会好奇这样一件事,我们在输入登录命令时用的是mysql,而在启动mysql服务上怎么使用的是mysqld,这两个东西有什么区别吗?接下来笔者谈一谈什么是mysql,什么是mysqld

MySQL主要分为了mysql客户端,mysqld服务器端,如下图

 

mysql客户端就是直接给我们用户提供服务的,像我们前面在命令行中输入的SQL语句,就是在mysql客户端上操作的,然后客户端会将我们输入的SQL命令发送给mysql服务器端,也就是给mysqld。

那么mysqld会把我们输入的命令进行分析和优化操作,然后执行这些命令,在磁盘的数据库文件中更新执行后的结果,然后把执行结果返还给mysql客户端,让客户知道命令执行的如何

现在我们详谈在使用mysql -u root -p命令前为什么要启动mysqld

因为命令mysql -u root -p这个语句意思就是打开mysql客户端,并且与mysqld建立连接,如果你没有启动mysqld,那么就无法与数据库服务器建立连接,那么你的SQL命令就无法发送给服务器端进行处理,也就是无法使用数据库了

客户端和服务器端可能安装在两台计算机或一台计算机上。不管它们在不在相同的计算机上,为进行所有数据库交互,客户端软件都要与服务器端软件进行通信(这句话来自《mysql必知必会》)

我们目前使用的MySQL其实客户端软件和服务器端软件是安装在一台计算机上的,怎么证明呢?如果你足够细心,在安装MySQL时会看到下面这些信息

这些信息表明,客户端软件和服务器端软件都安装在你当前的计算机上

注意:目前我们使用的客户端软件提供的是命令行式的操作,但这并不意味着只能进行命令行操作,我们可以根据自己的需要选择图形化界面的客户端,以及未来在编程中,通过编程语言与mysqld建立连接,这些都是可以的。

mysql客户端只是一种方便与MySQL服务器进行交互的方式,习惯命令行界面的就用命令行式的(默认下载的mysql客户端都提供命令行操作),习惯图形化界面的就用图形化界面的客户端,想程序与数据库直接建立连接的,就通过编程语言与mysqld建立连接

下面这张图,是MYSQL的一个结构图

简单提一下存储引擎(简单了解)

存储引擎:数据库管理系统如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。
MySQL的核心就是插件式存储引擎,支持多种存储引擎

 

下面这张图能够很好的帮我们前面的内容串联起来,Client就是客户端,MYSQL就是服务器端,DB就是我们在上面演示建立的数据库,数据库中存放着我们创建的表,我们在客户端写下create database blog_test 这个sql语句,那么客户端会将这个语句发送给服务器端处理,服务器接收到指令后,在存储区域更新这个操作,创建了一个DB,名为blog_test,同时将创建结果返回给客户端

其实创建一个数据库就是创建一个目录,而创建一张表就是创建一个文件,严格来说,真正在磁盘中存储的数据才是数据库,只不过我们日常口语叫惯了,把数据库这个概念叫的更加宽泛了

 

到此,我们算是把MySQL基础原理模糊的讲了一遍,其中很多概念可能我们一时无法理解,不用着急,这需要我们不断去学习完善,。还有很多SQL语法命令等着我们去掌握,这些是作为一个使用者必须要掌握的。像存储引擎,SQL语句的解析和优化等这些内容就没那么重要了,如果不深入数据库这个方向的发展,那么这些内容知道有就行了,用到的话,再去学习。程序的世界真的是太深太广了,想学完所有的东西那是不可能的,所以IT行业的人员要有持续学习的能力,暂时用不到的知识,不必追求一定掌握,但心中要留个痕迹,这样未来用到了才知道要学什么,从哪里学

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

HNU计算机体系结构-实验一:RISC-V指令理解

HNU计算机体系结构-实验一 前言1.实验目的2.实验步骤1.安装模拟器Ripes2.生成汇编指令3.思考问题1)指令add x15, x14, x152)指令bge x15 x14 -683)指令lw x15, -20 x84)指令sw x15, -20 x85)简述BranchE信号的作用6&am…

中级前端笔试面试题总结

typeof null 的结果是什么,为什么? typeof null 的结果是Object。 在 JavaScript 第一个版本中,所有值都存储在 32 位的单元中,每个单元包含一个小的 类型标签(1-3 bits) 以及当前要存储值的真实数据。类型标签存储在每个单元的…

(浙大陈越版)数据结构 第三章 树(中) 二叉搜索树和平衡二叉树

目录 4.1.1 二叉搜索树及查找 什么是二叉搜索树 定义 二叉搜索树特殊函数集: 查找操作:Find 算法思想 代码实现 补:查找最大和最小元素 4.1.2 二叉搜索树的插入 插入操作:Insert 算法思想 代码实现 例题 4.1.3 二叉…

吴恩达老师《机器学习》课后习题1之线性回归

在学习这些内容之前,需要学习python数据分析相关内容: numpy:科学计算库,处理多维数组,进行数据分析 pandas:基于numpy的一种工具,该工具是为了解决数据分析任务而创建的 matplotlib&#xff1a…

如何进行微服务测试?

微服务测试是一种特殊的测试类型,因为它涉及到多个独立的服务。以下是进行微服务测试的一般性步骤: 1. 确定系统架构 了解微服务架构对成功测试至关重要。确定每个微服务的职责、接口、依赖项和通信方式。了解这些信息可以帮助您更好地规划测试用例和测…

Aop详解

AOP简介 AOP是一种编程思想,就如同面向对象这种编程思想一样,是一种编程范式,用来指导开发者如何组织程序更好的运行 AOP(面向切面编程) 作用:在不改变原代码的前提下,为其增加功能。 连接点…

Apikit 自学日记:导入第三方产品 API 数据

除了手动创建API文档,系统也提供了一键导入 Swagger、Postman、RAP、YAPI 等产品数据的功能。方便从其他平台进行迁移。 产品支持度导入文件的后缀名Eolinker API 研发管理完全支持.jsonPostman V2.1支持导入API基础信息,超过10级分组的API数据将不会被导…

git在windows及linux(源码编译)环境下安装

git在windows及linux(源码编译)环境下安装 环境信息: 系统版本:CentOS Linux release 7.9.2009 (Core) git指令安装: yum install -y git 一、git在windows下安装 下载地址:https://git-scm.com/ 默认安装即可 验证 git --version 二、git在linux下安装 下载地址…

游戏场景的转换——状态模式

状态模式 游戏比较复杂时,通常会设计成多个场景。 切换场景的好处 1、重复使用场景 跳转切换场景的代码有两种一种是旧版的方法 Application.LoadLevel(“SampleScene”);另一种是新版的方法 SceneManager.LoadScene(“SampleScene”); 例子1:通过场景…

【QT】TCP/UDP详解及实现

TCP/UDP TCP/IP模型TCP协议头部格式三次握手四次挥手 UDP协议头部格式 Socket编程tcpudp代码实现服务端:客户端: 总结 TCP/IP模型 TCP模型是一个常见的网络协议参考模型,也称为TCP/IP模型或互联网模型。它是指TCP/IP协议族中的一组协议&…

Creating Add-in Hooks (C#)

本文介绍如何使一个文件在添加、检入、检出到库时,让add-in 程序在SOLIDWORKS PDM Professional 中通知到你。 注意: 因为 SOLIDWORKS PDM Professional 无法强制重新加载Add-in程序 ,必须重新启动所有客户端计算机,以确保使用最…

【Python开发】FastAPI 09:middleware 中间件及跨域

FastAPI 提供了一些中间件来增强它的功能,类似于 Spring 的切面编程,中间件可以在请求处理前或处理后执行一些操作,例如记录日志、添加请求头、鉴权等,跨域也是 FastAPI 中间件的一部分。 目录 1 中间件 1.1 创建中间件 1.2 使…

MySQL常见问题

优化慢查询 慢查询可能出现的情况: 聚合查询多表查询表数据量过大深度分页查询 表象:页面加载过慢,接口压测响应时间过长(超过1s) 如何定位慢查询? 方案一:开源工具 可以使用相应的调试工具&a…

EMC学习笔记(三)滤波

滤波 1.概述2.滤波器件2.1 电阻2.2 电感2.3 电容2.4 铁氧体磁珠2.5 共模电感 3.滤波电路3.1 滤波电路的形式3.2 滤波电路的布局与布线 4.电容在PCB的EMC设计中的应用4.1 滤波电容的种类4.2 电容自谐振问题4.3 ESR对并联电容幅频特性的影响4.4 ESL对并联电容幅频特性的影响4.5 电…

LarkXR知识库 | 开发者社区FAQ合集(二)

LarkXR是一套基于GPU云化、图形容器、音视频实时编解码、网络传输优化等核心技术的通用型实时云渲染解决方案,帮助XR领域企业级用户及开发者快速搭建XR应用上云通道,使其在各类智能终端上流畅的运行、使用及传播。 平行云开发者社区上线以来&#xff0c…

【计算机网络复习之路】运输层(谢希仁第八版)万字详解 主打基础

专栏:计算机网络复习之路 运输层是OSI七层模型中最重要最关键的一层,是唯一负责总体数据传输和控制的一层。运输层要达到两个主要目的:第一,提供可靠的端到端的通信(“端到端的通信” 是应用进程之间的通信&#xff09…

HTML type=“radio“ 不显示按钮

问题 HTML中type&#xff1d;"radio" 但是在界面中不显示按钮。 详细问题 HTML中type&#xff1d;"radio" 但是在界面中不显示按钮。 笔者html核心代码 <div>性别<input type"radio" id"male" name"gender" va…

Jmeter HTTP Cookie管理器的使用

目录 前言&#xff1a; 1、在HTTP信息头管理器组件中添加Cookie信息 &#xff08;1&#xff09;测试计划内包含的元件 &#xff08;2&#xff09;请求取样器内容 &#xff08;3&#xff09;HTTP信息头管理器内容 &#xff08;4&#xff09;查看结果 2、使用HTTP Cookie管…

年度创新企业奖!移远通信成推动AIoT融合落地关键力量

6月8日&#xff0c;由ASPENCORE主办的2023国际AIoT生态发展大会在深圳召开&#xff0c;移远通信受邀出席大会并发表演讲&#xff0c;同时凭借在5G、AIoT等领域的持续创新荣获“年度创新企业”奖&#xff01; 5GAIoT“双引擎” 重塑物联产业 近些年&#xff0c;从互联网、物联网…

Git->分支

⭐作者介绍&#xff1a;大二本科网络工程专业在读&#xff0c;持续学习Java&#xff0c;努力输出优质文章 ⭐作者主页&#xff1a;逐梦苍穹 ⭐所属专栏&#xff1a;Git ⭐如果觉得文章写的不错&#xff0c;欢迎点个关注一键三连&#x1f609;有写的不好的地方也欢迎指正&#x…