【mysql】—— 数据库的操作

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 【mysql】—— 数据库的操作

序言:

在上篇文章我已经对数据库进行了详细的介绍,接下来我们就将上手学习操作的细节了。本篇文章便带领大家去学习有关库操作的基本知识!!!

 



 

(一)库的操作

1、 创建数据库

 

在上篇文章中我带大家简单的看了一下数据库的创建过程,本期我们便具体展开来谈谈其中的细节。

在MySQL中,可以使用  CREATE DATABASE 语句来创建数据库。下面是创建数据库的基本语法:

  • 其中,db_name database_name 是要创建的数据库的名称;
  • IF NOT EXISTS :可选参数,表示如果数据库已经存在则不执行创建操作;
  • CHARACTER SET: 指定数据库采用的字符集
  • COLLATE:  指定数据库字符集的校验规则

例如,要创建一个名为 "mydatabase" 的数据库,可以使用以下命令:

create database mydatabase;

 

当我们重新另起一个页面进入【/var/lib/mysql】目录下时,我们可以发现此时目录下多出了一个【mydatabase】的目录:

此时,假设由于创建的数据库太多了,导致自己创建的数据库名字忘掉了。此时,我们可以添加一些设置操作:

【分析】

  • 这条语句将检查数据库是否已经存在。如果数据库尚未存在,则会创建名为 "mydatabase" 的数据库;
  • 如果数据库已经存在,则不执行任何操作。很明显,上述我们床架了一个名为【mydatabase】的数据库,因此不会被重新创建

 

紧接着,当我们想删除掉这个数据库时,应该怎么做呢?此时,我们像下述这样:

  • 要删除名为 "mydatabase" 的数据库,可以使用以下命令:
drop database mydatabase;

 

 

因此,我们不难发现,在mysql 环境下创建数据库相当于在【/var/lib/mysql】增加一个文件而已。那么,我们也可以直接在【/var/lib/mysql】下创建一个文件是不是就相当于在 mysql 环境下创建一个数据库呢? 具体如下:

结果显而易见,我们可以进行这样的操作,但是此时会有一个问题,那就是当我们我们在【/var/lib/mysql】想删除时,我们却无法进行 相关操作:

  • 而当我们在 mysql 环境下使用指令删除时,我们是可以正确的删除的:

 


2、字符集和校验规则

  • 创建名为 db1 的数据库
create database db1;

说明

       当我们创建数据库没有指定字符集和校验规则时,系统使用默认字符集:utf8,校验规则是:utf8_ general_ ci

在MySQL中创建数据库时,常用的两个字符集编码:

  • 数据库编码集:数据库未来存储数据;
  • 数据库校验集:支持数据库,进行字段比较使用的编码,本质也是一种读取数据库中数据采用的编码格式;

1️⃣ 查看系统默认字符集以及校验规则

 

要查看MySQL数据库系统的默认字符集和校对规则,可以使用以下查询语句:

  • 查询结果将会返回类似下面的信息:

  • 第一条查询语句将显示与字符集相关的系统变量

  • 第二条查询语句将显示与校对规则(排序规则)相关的系统变量。

2️⃣ 查看数据库支持的字符集

show charset;

当使用 SHOW CHARSET;命令时,MySQL会显示当前数据库中可用的字符集,并提供相关信息,例如字符集名称、默认排序规则和描述。

  • 以下是执行 SHOW CHARSET;查询的示例输出:

 

3️⃣ 查看数据库支持的字符集校验规则

show collation;

当使用 SHOW COLLATION;命令时,MySQL将显示当前数据库中可用的校对规则(排序规则),并提供相关信息,例如校对规则名称、字符集、ID和描述。

  • 以下是执行 SHOW COLLATION; 查询的示例输出的一部分:

查询结果将列出可用的校对规则及其相关信息,如校对规则名称、字符集、ID、是否为默认校对规则(Default)、是否已编译(Compiled)以及排序长度(Sortlen)。

4️⃣ 创建数据库案例

 

💨 创建一个使用utf8字符集的 db2 数据库

create database db2 charset=utf8;
  • 显示如下:

💨 创建一个使用utf字符集,并带校对规则的 db3 数据库

create database db3 charset=utf8 collate utf8_general_ci;
  • 显示如下:

 

5️⃣ 校验规则对数据库的影响

  • 不区分大小写

创建一个数据库,校验规则使用 utf8_ general_ ci [不区分大小写]

 

create database test1 collate utf8_general_ci;

显示如下:

 

紧接着进入表中,在进行建表操作:

 进行查询:

结果排序:

 

 

 

  • 区分大小写

创建一个数据库,校验规则使用 utf8_ bin [区分大小写]

 

create database test2 collate utf8_bin;

显示如下:

紧接着进入表中,在进行建表操作:

 

 进行查询:

 结果排序:

 


(二)操纵数据库

1、查看数据库

show databases;

这个就不过多介绍了,在之前我们一直再用。

此外,我在给大家介绍一个新的东西:

  • SELECT DATABASE(); 是一个MySQL查询,用于获取当前正在使用的数据库的名称。

当你执行这个查询时,它将返回当前正在使用的数据库的名称作为结果。例如,如果当前正在使用的数据库是"test2",那么执行 SELECT DATABASE(); 将返回如下结果:

  • 请注意,这是一个只返回结果的查询,不会对数据库进行任何修改或操作

2 、显示创建语句

 

show create database 数据库名;

示例:

【分析】

  1. MySQL 建议我们关键字使用大写,但是不是必须的。
  2. 数据库名字的反引号``,是为了防止使用的数据库名刚好是关键字
  3. /*!40100 default.... */ 这个不是注释,表示当前mysql版本大于4.01版本,就执行这句话

3、修改数据库

语法:

 

ALTER DATABASE db_name

[alter_spacification [,alter_spacification]...]

alter_spacification:

[DEFAULT] CHARACTER SET charset_name

[DEFAULT] COLLATE collation_name

说明:

  • 对数据库的修改主要指的是修改数据库的字符集,校验规则

实例: 将 test2 数据库字符集改成 gbk

 

4、数据库删除

 

语法:

DROP DATABASE [IF EXISTS] db_ name;

示例:删除test1

 

执行删除之后的结果:

  • 数据库内部看不到对应的数据库
  • 对应的数据库文件夹被删除,级联删除,里面的数据表全部被删

💨 注意:不要随意删除数据库

5、查看连接情况

语法:

 

show processlist

输出显示:

可以告诉我们当前有哪些用户连接到我们的MySQL,如果查出某个用户不是你正常登陆的,很有可能你的数据库被人入侵了。以后大家发现自己数据库比较慢时,可以用这个指令来查看数据库连接情况。

 

6、备份和恢复

1️⃣备份

在MySQL中,可以使用多种方法进行数据库的备份和恢复。以下是两种常用的方法:

  • 使用 mysqldump 工具进行备份和恢复:

备份数据库:可以使用以下命令来备份整个数据库:

# mysqldump -P3306 -u root -p 密码 -B 数据库名 > 数据库备份存储的文件路径

例如,要备份名为"db1"的数据库,使用以下命令:

mysqldump -P3306 -u root -p123456 -B db1> db1.sql

  • 这将把整个数据库保存到名为"db1.sql"的SQL文件中。

恢复数据库:可以使用以下命令来还原数据库:

mysql -u 用户名 -p 数据库名 < 备份文件.sql

例如,要还原名为"db1"的数据库,使用以下命令:

mysql -u root -p db1< db1.sql

  1. 这将从"db1.sql"文件中读取SQL语句,并还原数据库。
  • 使用物理文件拷贝进行备份和恢复:

备份数据库:可以直接拷贝MySQL数据目录来备份数据库。首先停止MySQL服务,然后复制MySQL数据目录到备份位置即可。

恢复数据库:要恢复数据库,只需将备份的数据目录拷贝回MySQL数据目录的原始位置,并确保相应的权限和所有权设置正确。然后重新启动MySQL服务即可。

无论使用哪种方法,都建议定期备份数据库以确保数据的安全性,并根据需要进行恢复。

2️⃣注意事项

如果备份的不是整个数据库,而是其中的一张表,怎么做?

 

# mysqldump -u root -p 数据库名 表名1 表名2 > db1.sql

同时备份多个数据库

 

# mysqldump -u root -p -B 数据库名1 数据库名2 ... > 数据库存放路径

  • 如果备份一个数据库时,没有带上【-B】 参数, 在恢复数据库时,需要先创建空数据库,然后使用数据库,再使用source来还原

总结

到此,关于本文的内容便讲解结束了。感谢大家的观看与支持!!!

 

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
4天前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!点击阅读原文完成实验就可获得一本日历哦~
|
8天前
|
关系型数据库 MySQL 数据库
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
|
5天前
|
人工智能 小程序 关系型数据库
【MySQL】黑悟空都掌握的技能,数据库隔离级别全攻略
本文以热门游戏《黑神话:悟空》为契机,深入浅出地解析了数据库事务的四种隔离级别:读未提交、读已提交、可重复读和串行化。通过具体示例,展示了不同隔离级别下的事务行为差异及可能遇到的问题,如脏读、不可重复读和幻读等。此外,还介绍了在MySQL中设置隔离级别的方法,包括全局和会话级别的调整,并通过实操演示了各隔离级别下的具体效果。本文旨在帮助开发者更好地理解和运用事务隔离级别,以提升数据库应用的一致性和性能。
51 2
【MySQL】黑悟空都掌握的技能,数据库隔离级别全攻略
|
7天前
|
SQL 关系型数据库 MySQL
【MySQL 慢查询秘籍】慢SQL无处遁形!实战指南:一步步教你揪出数据库性能杀手!
【8月更文挑战第24天】本文以教程形式深入探讨了MySQL慢SQL查询的分析与优化方法。首先介绍了如何配置MySQL以记录执行时间过长的SQL语句。接着,利用内置工具`mysqlslowlog`及第三方工具`pt-query-digest`对慢查询日志进行了详细分析。通过一个具体示例展示了可能导致性能瓶颈的查询,并提出了相应的优化策略,包括添加索引、缩小查询范围、使用`EXPLAIN`分析执行计划等。掌握这些技巧对于提升MySQL数据库性能具有重要意义。
34 1
|
9天前
|
关系型数据库 MySQL Linux
在Linux中,如何配置数据库服务器(如MySQL或PostgreSQL)?
在Linux中,如何配置数据库服务器(如MySQL或PostgreSQL)?
|
9天前
|
SQL 关系型数据库 MySQL
【揭秘】MySQL binlog日志与GTID:如何让数据库备份恢复变得轻松简单?
【8月更文挑战第22天】MySQL的binlog日志记录数据变更,用于恢复、复制和点恢复;GTID为每笔事务分配唯一ID,简化复制和恢复流程。开启binlog和GTID后,可通过`mysqldump`进行逻辑备份,包含binlog位置信息,或用`xtrabackup`做物理备份。恢复时,使用`mysql`命令执行备份文件,或通过`innobackupex`恢复物理备份。GTID模式下的主从复制配置更简便。
47 2
|
10天前
|
数据可视化 关系型数据库 MySQL
Mysql8 如何在 Window11系统下完成跳过密钥校验、完成数据库密码的修改?
这篇文章介绍了如何在Windows 11系统下跳过MySQL 8的密钥校验,并通过命令行修改root用户的密码。
Mysql8 如何在 Window11系统下完成跳过密钥校验、完成数据库密码的修改?
|
12天前
|
SQL 存储 关系型数据库
数据库-MySQL-01(一)
数据库-MySQL-01(一)
16 4
|
17天前
|
缓存 NoSQL Redis
一天五道Java面试题----第九天(简述MySQL中索引类型对数据库的性能的影响--------->缓存雪崩、缓存穿透、缓存击穿)
这篇文章是关于Java面试中可能会遇到的五个问题,包括MySQL索引类型及其对数据库性能的影响、Redis的RDB和AOF持久化机制、Redis的过期键删除策略、Redis的单线程模型为何高效,以及缓存雪崩、缓存穿透和缓存击穿的概念及其解决方案。
|
10天前
|
安全 关系型数据库 MySQL
MySQL非root安装-初始化数据库时unknown variable ‘defaults-file=**/my.cnf‘
解决安装过程中出现的问题通常需要仔细地检查错误日志、配置文件和执行命令,保证各项配置设置的精确无误是顺利完成安装的关键。通过上述的步骤分析和解决方案,非root用户安装MySQL时遇到"unknown variable 'defaults-file=**/my.cnf'"的问题应该可以得到妥善的解决。
25 0

热门文章

最新文章

下一篇
云函数