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

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

在这篇文章里,笔者将着重讲解如何在win和Linux系统上安装自己的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行业的人员要有持续学习的能力,暂时用不到的知识,不必追求一定掌握,但心中要留个痕迹,这样未来用到了才知道要学什么,从哪里学



相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
2月前
|
SQL 关系型数据库 数据库
Python SQLAlchemy模块:从入门到实战的数据库操作指南
免费提供Python+PyCharm编程环境,结合SQLAlchemy ORM框架详解数据库开发。涵盖连接配置、模型定义、CRUD操作、事务控制及Alembic迁移工具,以电商订单系统为例,深入讲解高并发场景下的性能优化与最佳实践,助你高效构建数据驱动应用。
372 7
|
3月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
163 3
|
3月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
3月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
801 152
|
3月前
|
关系型数据库 MySQL 分布式数据库
阿里云PolarDB云原生数据库收费价格:MySQL和PostgreSQL详细介绍
阿里云PolarDB兼容MySQL、PostgreSQL及Oracle语法,支持集中式与分布式架构。标准版2核4G年费1116元起,企业版最高性能达4核16G,支持HTAP与多级高可用,广泛应用于金融、政务、互联网等领域,TCO成本降低50%。
|
3月前
|
关系型数据库 分布式数据库 数据库
阿里云数据库收费价格:MySQL、PostgreSQL、SQL Server和MariaDB引擎费用整理
阿里云数据库提供多种类型,包括关系型与NoSQL,主流如PolarDB、RDS MySQL/PostgreSQL、Redis等。价格低至21元/月起,支持按需付费与优惠套餐,适用于各类应用场景。
|
3月前
|
SQL 关系型数据库 MySQL
Mysql数据恢复—Mysql数据库delete删除后数据恢复案例
本地服务器,操作系统为windows server。服务器上部署mysql单实例,innodb引擎,独立表空间。未进行数据库备份,未开启binlog。 人为误操作使用Delete命令删除数据时未添加where子句,导致全表数据被删除。删除后未对该表进行任何操作。需要恢复误删除的数据。 在本案例中的mysql数据库未进行备份,也未开启binlog日志,无法直接还原数据库。
|
3月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
447 7
|
3月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(上)
最终建议:当前系统是完美的读密集型负载模型,优化重点应放在减少行读取量和提高数据定位效率。通过索引优化、分区策略和内存缓存,预期可降低30%的CPU负载,同时保持100%的缓冲池命中率。建议每百万次查询后刷新统计信息以持续优化
247 6
|
3月前
|
缓存 监控 关系型数据库
使用MYSQL Report分析数据库性能(中)
使用MYSQL Report分析数据库性能
170 1

热门文章

最新文章

推荐镜像

更多