【MySQL】库的相关操作 + 库的备份和还原

库的操作

  • 前言
  • 正式开始
    • 创建数据库
    • 删除数据库
    • 编码集
      • 查看系统默认字符集以及校验规则
        • 字符集
        • 校验规则
      • 所有支持的字符集和校验规则
        • 所有字符集
        • 所有校验规则
      • 指明字符集和校验规则创建数据库
      • 相同的字符集用不同的校验规则读取会出现什么情况
    • alter修改数据库
      • show create database
      • alter
    • 库的备份和恢复
      • mysqldump备份整个库
      • mysqldump备份某张(某几张)表

在这里插入图片描述

前言

如果你对于数据库的一些基本概念还不太理解,可以看看我上一篇:
【MySQL】想不想知道数据库到底是啥?想了就进来看看

本篇主要讲解:
创建、删除、修改数据库。
对库做备份和还原。

正式开始

本来是不向给出下面这张图的:
在这里插入图片描述

因为我觉得新手根本就没法理解,而且还容易被这种一大堆括号的东西吓到,但是这里还是给出来,不过我不会照着这个讲,我按照更容易理解的方式来走。

创建数据库

先简单介绍一下基本操作,等会再讲细节。

create database xxx;

注意,sql语句大写小写都是可以的,不要认为只能大写,我后面全用小写来讲。

在这里插入图片描述

我前一篇说过,创建一个数据库就会在配置文件给的datadir所给的路径下创建一个目录:

在这里插入图片描述

看:
在这里插入图片描述
创建数据库的时候还可以加上if not exists,作用就是判断一下有没有,没有就创建,有了就不起作用:
在这里插入图片描述

删除数据库

drop database xxx;

在这里插入图片描述

对应的也就是删除目录:
在这里插入图片描述

那么我在datadir路径下创建一个目录,那么在show databases的时候也是能看到的:
在这里插入图片描述

再删掉这个目录,对应show 的时候也就消失了:
在这里插入图片描述

但是通过手动创建目录的方式是创建不出来数据库的,虽然能用use选中数据库,但是创建不出来表。必须通过sql语句来创建数据库。

注意,删除数据库就是删目录,目录只要一删除,其中的表和数据就都没了,所以特别不推荐直接对数据库做删除操作,如果要删,必须先确定其中的数据还有没有用,以防万一也可以做一下备份(备份怎么做等会会讲到)。

编码集

创建数据库的时候会有两个编码集:字符集和校验规则。

只要有数据,存储的时候一定是要有编码格式的,数据库就主要是与数据打交道的,所以就必须非常注重编码集,编码集必须是统一的,存的时候用什么编码,取的时候就要用与之对应的编码来取。

比如说一张纸上写着一堆中文,那就必须懂中文才能懂纸上写的是啥东西,用英文来读中文是不可能读懂的。

存数据的时候看的是字符集,取数据的时候看的是校验规则。上面的这个简单的例子中,中文就是存放的数据,所以中文的语法规则就指的是字符集,用什么语言来读就是用什么校验规则,英文的校验规则(语法、单词啥的)和中文对不上,那就读不懂。

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

show variables like 'character_set_database'; # 查看字符集
show variables like 'collation_database'; # 查看校验规则
字符集

在这里插入图片描述
可能你执行这条语句后结果是latin1,没关系,因为我前面配置文件中设置了我的mysqld默认的编码格式为utf8:
在这里插入图片描述

再来看一下当前数据库8个变量所用的字符集:
在这里插入图片描述

关于这几个character_set,想要详细了解的可以看这篇:
关于MySQL中的8个 character_set 变量说明

校验规则

在这里插入图片描述

这里的utf8_general_ci是和utf8对应的,存的时候用utf8,取的时候用utf8_general_ci。

当前数据库中连接、创建数据库、服务的校验规则:
在这里插入图片描述

所有支持的字符集和校验规则

所有字符集

在这里插入图片描述

其中就有utf8,对应的默认校验规则就是utf8_genral_ci。

所有校验规则

非常多:
在这里插入图片描述

我也把utf8_general_ci圈出来了。

这些所有的编码集都是可选的,不过我这里默认情况下用的是utf8,等会创建数据库的时候也可以做修改。

指明字符集和校验规则创建数据库

先来一个默认字符集的:
在这里插入图片描述

我前一篇说过创建一个数据库,其中会有一个文件,但没有说这个文件中的内容是啥,这里就能知道了,就是默认的字符集和校验规则,因为创建数据库d1的时候并没有指明字符集和校验规则,所以就用的默认字符集和校验规则。

再来指明字符集和校验规则来创建:

  • 指明字符集为utf8:
    在这里插入图片描述

有多种写法:
在这里插入图片描述

中间的等号可以不加:
在这里插入图片描述

character set也是:
在这里插入图片描述

  • 指明校验规则为utf8_general_ci:
    我这里把刚刚创建出来的5个全删掉,不然影响观察。

在这里插入图片描述

也是可以不加等号,换成utf8_bin试试:
在这里插入图片描述

换成和utf8完全不相关的:
在这里插入图片描述

可以看到mysqld还是很聪明的,会自动换成匹配的字符集。

  • 指明字符集为utf8,校验规则为utf8_general_ci:
    再把刚刚的三个删掉。

在这里插入图片描述

指明utf8 和 utf8_bin
在这里插入图片描述

指明 latin1 和 latin1_bin:
在这里插入图片描述

如果指明的字符集和校验规则不匹配:
在这里插入图片描述
会出错。

相同的字符集用不同的校验规则读取会出现什么情况

下面的两个d1和d2字符集用的都是utf8,但d1的校验规则是utf8_general_ci,d2的校验规则用的是utf8_bin。
在这里插入图片描述

utf8_general_ci是不区分大小写的,但utf8_bin区分,但是光说也体会不出来,得创建两个表看看。

对数据库操作时必须先选中数据库:use db_name。

先选定d1建一张表:
在这里插入图片描述

表的相关操作我后续博客会详谈,这里先认识一下。

这里创建了一个person表,其中有一列,往里面插入点数据:
在这里插入图片描述
我往里面插入了小写的a、b、c,又插入了大写的A、B、C。

插入的本质就是存,那么存的时候用的就是字符集,select查询的时候是取,取的时候要进行对比库中的数据和你想取的数据是否一致,所以用的就是编码集。

查看一下其中的a:
在这里插入图片描述

这里查出来了两个,一个a,一个A。这就可以说明utf8_general_ci是不区分大小写的。

再来按照name升序排序:
在这里插入图片描述
排序的时候要进行比较,比较就要对其编码进行校验,所以用的是校验集,可以看到小写和大写是放在一块的,都是一样的。

再用d2做同样的工作:
在这里插入图片描述
d2却只查出来了a。所以utf8_bin区分大小写。

排序:
在这里插入图片描述

大写在前,小写在后,其实这里就是按照ASCII排的。

后面我创建库默认的字符集就是utf8,默认校验规则就是utf8_general_ci。

数据库的字符集和校验规则会间接(并非直接,你也可以再改)影响库中表的字符集和校验规则,不过这都是后话了,等我下一篇讲表的操作的时候再细说。

alter修改数据库

show create database

不过说alter之前先说一下这个:

show create database xxx; # xxx为数据库名 

这条语句可以查看你在创建xxx数据库的时候的细节(其实就是编码的细节,没有别的)。

比如说刚刚的d1和d2:
在这里插入图片描述

alter

再来说alter,一般alter操作是为了修改数据库编码的。

来改一下d1:
在这里插入图片描述

改了之后的db.opt文件:
在这里插入图片描述
show:
在这里插入图片描述

再来看看d2,改成gbk:
在这里插入图片描述

这里gbk_chinese_ci就是gbk的默认校验规则,所以没有显示。

到这里库的增(create)删(drop)查(show)改(alter)工作就已经搞完了。

下面说说库的备份和恢复

库的备份和恢复

如何在Linux中对一个文件做备份?
很简单,cp一下再重命名或者直接重命名就行。

那数据库文件也是一个文件,能不能也像普通文件那样备份呢?
不行。mysql专门给出了备份相关的操作的。

mysqldump备份整个库

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

就拿刚刚的d1来做备份。

在这里插入图片描述
注意这个路径下是空的。就备份到这个路径下面。
在这里插入图片描述

可以看到其中多了一个文件。

用vim打开,里面的内容是这样的:

在这里插入图片描述

里面保存了历史上做过的一些操作,不光是存放数据。

现在我删除掉d1:
在这里插入图片描述

现在datadir中就不存在d1这个目录了。

现在想要快速恢复出d1,怎么搞呢?
source。

在这里插入图片描述

直接source后面跟路径,就能将历史中记录的sql命令全部执行一次。

此时就d1就还原了:
在这里插入图片描述

其实上面的操作还可以搞成远端的,现在本地搞个备份,然后发送到远端的另一台主机上,这样那台主机专门用来做备份,等出现问题的时候再将备份通过远端发回来就好。

注意备份整个库的时候一定要加上-B,不然就没有备份上,备份出来的是空的。

mysqldump备份某张(某几张)表

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

mysqldump -u root -p 数据库名 表名1 表名2 > D:/mytest.sql

我先来再创建三张表:
在这里插入图片描述

删掉person表,此时只有这三个:
在这里插入图片描述

备份:
在这里插入图片描述

解释一下,这里因为我配置文件中设置了不需要密码,所以没有加-p。
d1就是数据库名,person、t1、t3就是表名。

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

删掉d1数据库:
在这里插入图片描述
再创建一个空的d1:
在这里插入图片描述

注意一定要先选中数据库再进行还原,不然就出错:
在这里插入图片描述

选中后:
在这里插入图片描述

因为刚刚只备份了t1和t3,所以还原出来的只有这两张表:
在这里插入图片描述

注意,如果你备份整个数据库的时候没有加上-B,那还原的时候也得要先创建一个数据库,然后再选中这个数据库才能还原:
在这里插入图片描述

如果备份整个数据库没有加B,可以实现对数据库重命名:
在这里插入图片描述

上面用的还是刚刚d1备份的数据,但是可以直接还原到test中。

其实mysql以前是支持重命名的,但是现在不支持了。

库的操作该讲的都讲了,下一篇说表的操作。

补充一个小点:
show processlist可以显示当前数据库的连接情况。
在这里插入图片描述
这里只有我一个root用户登录。

到此结束。。。

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

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

相关文章

深入理解Kafka3.6.0的核心概念,搭建与使用

Kafka是最初由Linkedin公司开发,是一个分布式、支持分区的(partition)、多副本的(replica),基于zookeeper协调的分布式消息系统,它的最大的特性就是可以实时的处理大量数据以满足各种需求场景&a…

OpenMMlab导出yolov3模型并用onnxruntime和tensorrt推理

导出onnx文件 直接使用脚本 import torch from mmdet.apis import init_detector, inference_detectorconfig_file ./configs/yolo/yolov3_mobilenetv2_8xb24-ms-416-300e_coco.py checkpoint_file yolov3_mobilenetv2_mstrain-416_300e_coco_20210718_010823-f68a07b3.pth…

跨境电商源码:多语言支持与扩展的终极解决方案

随着全球电商市场的不断扩大,跨境电商源码的需求日益增长。对于想要拓展国际业务的电商企业来说,多语言支持显得尤为重要。在这方面,我们的跨境电商源码产品具备显著优势,不仅全面支持多语言,还方便扩展多个语言的CSDN…

PP-ChatOCRv2、PP-TSv2、大模型半监督学习工具...PaddleX新特性等你来pick!

小A是一名刚刚毕业的算法工程师,有一天,他被老板安排了一个活,要对一批合同扫描件进行自动化信息抽取,输出结构化的分析报表。OCR问题不大,但是怎么进行批量的结构化信息抽取呢?小A陷入了苦苦思索... 小B是…

【06】VirtualService高级流量功能

5.3 weight 部署demoapp v10和v11版本 --- apiVersion: apps/v1 kind: Deployment metadata:labels:app: demoappv10version: v1.0name: demoappv10 spec:progressDeadlineSeconds: 600replicas: 3selector:matchLabels:app: demoappversion: v1.0template:metadata:labels:app…

数据结构:红黑树的原理和实现

文章目录 红黑树的概念红黑树的性质红黑树的模拟实现红黑树的平衡问题 整体实现和测试 本篇用于进行红黑树的拆解和模拟实现,为之后的map和set的封装奠定基础 红黑树的概念 红黑树也是一种二叉搜索树,但是在每一个节点的内部新增了一个用以表示该节点颜…

【python自动化】Playwright基础教程(八)鼠标操作

【python自动化】Playwright基础教程(八)鼠标操作 本文目录 文章目录 【python自动化】Playwright基础教程(八)鼠标操作playwright系列回顾前文代码click模拟鼠标点击dblclick模拟鼠标双击down模拟鼠标按下move模拟鼠标移动up模拟鼠标释放wheel模拟鼠标滚动鼠标长按常用实战引…

mysql数据库可以执行定时任务

在一些业务需要中,经常需要一些定时任务。如Java的schedule,nodejs的node-schedule等。今天第一次接触了使用数据库的存储过程来执行定时任务。 本篇文章以MySQL数据库为例,介绍通过数据库设置定时任务的方法。本文中以介绍操作过程为主&…

三数之和问题

题目描述 给你一个整数数组 nums ,判断是否存在三元组 [nums[i], nums[j], nums[k]] 满足 i ! j、i ! k 且 j ! k ,同时还满足 nums[i] nums[j] nums[k] 0 。请你返回所有和为 0 且不重复的三元组。 注意:答案中不可以包含重复的三元组。…

asp.net core mvc之 布局

一、布局是什么? 布局是把每个页面的公共部分,提取成一个布局页面(头、导航、页脚)。 二、默认布局 _Layout.cshtml 默认的布局是在 /Views/Shared 目录的 _Layout.cshtml文件。通常Shared目录中的视图都是公共视图。该目录下的…

瑞利长度(Rayleigh length)

瑞利长度 Rayleigh length 在光学,特别是激光学中,我们设鞍腰部(如图中所示的最低处)为A,其横截面面积为a,沿光的传播方向,当横截面面积因为散射达到2a时,我们设此处为B,…

二维码智慧门牌管理系统升级解决方案:运营可视化之道

文章目录 前言一、系统概述二、数据可视化与运营决策 前言 随着科技的飞速发展和人们生活水平的提高,传统的门牌管理系统已经无法满足现代社会的需求。在这个信息化、智能化的时代,一款升级版的二维码智慧门牌管理系统应运而生,它将以全新的…

Vmware虚拟机重装 虚拟机能ping通主机,而主机不能ping通虚拟机的问题

CClean,用它把你电脑上已经卸载的软件但是注册表还没删干净的把注册表删干净,之前说的那种情况(虚拟网络编辑器打不上勾)就迎刃而解了。 Ps:CClean:再网上百度就可以查到,软件对用户也很友好&a…

(11.13 知识总结(路由层)

一、路由层 1.1路由匹配 1.1.1 什么是路由? 路由可以看成是跟在 ip 和 port 之后的地址 1.1.2 url( ) 方法 # 示例 urlpatterns [ url(r^admin/, admin.site.urls), url(r^login/, views.login_func), url(r^register/$, views.register_func), ] url…

【异步并发编程】使用aiohttp构建Web应用程序

文章目录 1. 写在前面1. 什么是aiohttp?1.1. 什么是异步编程? 2. 安装aiohttp3. 异步HTTP服务器4. 异步请求5. aiohttp REST实例 【作者主页】:吴秋霖 【作者介绍】:Python领域优质创作者、阿里云博客专家、华为云享专家。长期致力…

iOS:何为空指针和野指针

一:什么是空指针和野指针 1、空指针 ①.没有存储任何内存地址的指针就成为空指针(NULL指针) ②.空指针就是被赋值为0的指针,在没有被具体初始化之前,其值为0. //以下都是空指针,eg: Person *p1 NULL; …

Linux上C++通过LDAP协议使用kerberos认证AES加密连接到AD服务器

一.前言 记录自己在实现这个流程遇到的各种问题,因为我也是看了许多优质的文章以及组内大佬的帮助下才弄成的,这里推荐一个大佬的文章,写的非常优秀,比我这篇文章写得好得很多,最后我也是看这个大佬的代码最终才实现的…

一行JavaScrip可以做什么?

说在前面 JavaScript 提供了许多方便的方法和操作符来简化常见的任务,使得编程变得更加高效和便捷。无论是数学计算、字符串处理还是数据操作,JavaScript 都能帮助我们以简洁的方式实现所需功能。 代码 1、生成指定范围内的随机整数 const randomInt …

部分背包问题【贪心算法】

部分背包问题是一种经典的贪心问题,物品可以取一部分,也就是可以随意拆分的物品。 算法思路: 用列表保存每个物品的价值及总重量、平均价值(性价比)。输入数据同时计算每种物品的平均价值。使用自定义的compare函数以…

2023亚太杯数学建模思路 - 复盘:校园消费行为分析

文章目录 0 赛题思路1 赛题背景2 分析目标3 数据说明4 数据预处理5 数据分析5.1 食堂就餐行为分析5.2 学生消费行为分析 建模资料 0 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 1 赛题背景 校园一卡通是集…