前言

简单介绍一下数据库的维护。

正文

像所有数据一样,MySQL的数据也必须经常备份。

由于MySQL数据库是基于磁盘的文件,普通的备份系统和例程就能备份MySQL的数据。

但是,由于这些文件总是处于打开和使用状态,普通的文件副本备份不一定总是有效.

下面列出这个问题的可能解决方案。

1.使用命令行实用程序mysqldump转储所有数据库内容到某个外部
文件。在进行常规备份前这个实用程序应该正常运行,以便能正
确地备份转储文件。
2.可用命令行实用程序mysqlhotcopy从一个数据库复制所有数据
(并非所有数据库引擎都支持这个实用程序)。
3.可以使用MySQL的BACKUP TABLE或SELECT INTO OUTFILE转储所
有数据到某个外部文件。这两条语句都接受将要创建的系统文件
名,此系统文件必须不存在,否则会出错。数据可以用RESTORE
TABLE来复原。

注意:

首先刷新未写数据 为了保证所有数据被写到磁盘(包括索引
数据),可能需要在进行备份前使用FLUSH TABLES语句

数据库维护

以下是你应该知道的一些语句。

ANALYZE TABLE,用来检查表键是否正确。ANALYZE TABLE返回如
下所示的状态信息:

ANALYZE TABLE orders;

![](https://img2020.cnblogs.com/blog/1289794/202110/1289794-20211003210451726-680155548.png)

CHECK TABLE用来针对许多问题对表进行检查。在MyISAM表上还对
索引进行检查。CHECK TABLE支持一系列的用于MyISAM表的方式。
CHANGED检查自最后一次检查以来改动过的表。EXTENDED执行最
彻底的检查,FAST只检查未正常关闭的表,MEDIUM检查所有被删
除的链接并进行键检验,QUICK只进行快速扫描。如下所示,CHECK
TABLE发现和修复问题: CHECK TABLE orders,orderitems; ![](https://img2020.cnblogs.com/blog/1289794/202110/1289794-20211003210603941-412901133.png) 1. 如果MyISAM表访问产生不正确和不一致的结果,可能需要用REPAIR TABLE来修复相应的表。这条语句不应该经常使用,如果需要经常使用,可能会有更大的问题要解决。 2. 如果从一个表中删除大量数据,应该使用OPTIMIZE TABLE来收回所用的空间,从而优化表的性能。 #### 诊断启动问题 服务器启动问题通常在对MySQL配置或服务器本身进行更改时出
现。MySQL在这个问题发生时报告错误,但由于多数MySQL服务器是作
为系统进程或服务自动启动的,这些消息可能看不到。 在排除系统启动问题时,首先应该尽量用手动启动服务器。MySQL
服务器自身通过在命令行上执行mysqld启动。下面是几个重要的mysqld
命令行选项: 1. --help显示帮助——一个选项列表; 2. --safe-mode装载减去某些最佳配置的服务器; 3. --verbose显示全文本消息(为获得更详细的帮助消息与--help
联合使用); 4. --version显示版本信息然后退出。 #### 查看日志 MySQL维护管理员依赖的一系列日志文件。主要的日志文件有以下几种。 1. 错误日志。它包含启动和关闭问题以及任意关键错误的细节。此
日志通常名为hostname.err,位于data目录中。此日志名可用
--log-error命令行选项更改。 2. 查询日志。它记录所有MySQL活动,在诊断问题时非常有用。此
日志文件可能会很快地变得非常大,因此不应该长期使用它。此
日志通常名为hostname.log,位于data目录中。此名字可以用
--log命令行选项更改。 3. 二进制日志。它记录更新过数据(或者可能更新过数据)的所有
语句。此日志通常名为hostname-bin,位于data目录内。此名字
可以用--log-bin命令行选项更改。注意,这个日志文件是MySQL
5中添加的,以前的MySQL版本中使用的是更新日志。 4. 缓慢查询日志。顾名思义,此日志记录执行缓慢的任何查询。这
个日志在确定数据库何处需要优化很有用。此日志通常名为
hostname-slow.log ,位于 data 目录中。此名字可以用
--log-slow-queries命令行选项更改。 在使用日志时,可用FLUSH LOGS语句来刷新和重新开始所有日志文
件。 #### 改善性能 数据库管理员把他们生命中的相当一部份时间花在了调整、试验以
改善DBMS性能之上。在诊断应用的滞缓现象和性能问题时,性能不良的
数据库(以及数据库查询)通常是最常见的祸因。 可以看出,下面的内容并不能完全决定MySQL的性能。我们只是
想回顾一下前面各章的重点,提供进行性能优化探讨和分析的一个出
发点。  首先,MySQL(与所有DBMS一样)具有特定的硬件建议。在学
习和研究MySQL时,使用任何旧的计算机作为服务器都可以。但
对用于生产的服务器来说,应该坚持遵循这些硬件建议。
 一般来说,关键的生产DBMS应该运行在自己的专用服务器上。
 MySQL是用一系列的默认设置预先配置的,从这些设置开始通常
是很好的。但过一段时间后你可能需要调整内存分配、缓冲区大
小等。(为查看当前设置,可使用SHOW VARIABLES;和SHOW
STATUS;。)
 MySQL一个多用户多线程的DBMS,换言之,它经常同时执行多
个任务。如果这些任务中的某一个执行缓慢,则所有请求都会执
行缓慢。如果你遇到显著的性能不良,可使用SHOW PROCESSLIST
显示所有活动进程(以及它们的线程ID和执行时间)。你还可以用
KILL命令终结某个特定的进程(使用这个命令需要作为管理员登
录)。
 总是有不止一种方法编写同一条SELECT语句。应该试验联结、并、
子查询等,找出最佳的方法。  使用EXPLAIN语句让MySQL解释它将如何执行一条SELECT语句。
 一般来说,存储过程执行得比一条一条地执行其中的各条MySQL
语句快。
 应该总是使用正确的数据类型。  决不要检索比需求还要多的数据。换言之,不要用SELECT *(除
非你真正需要每个列)。  有的操作(包括INSERT)支持一个可选的DELAYED关键字,如果
使用它,将把控制立即返回给调用程序,并且一旦有可能就实际
执行该操作。  在导入数据时,应该关闭自动提交。你可能还想删除索引(包括
FULLTEXT索引),然后在导入完成后再重建它们。  必须索引数据库表以改善数据检索的性能。确定索引什么不是一
件微不足道的任务,需要分析使用的SELECT语句以找出重复的
WHERE和ORDER BY子句。如果一个简单的WHERE子句返回结果所花
的时间太长,则可以断定其中使用的列(或几个列)就是需要索
引的对象。  你的SELECT语句中有一系列复杂的OR条件吗?通过使用多条
SELECT语句和连接它们的UNION语句,你能看到极大的性能改
进。  索引改善数据检索的性能,但损害数据插入、删除和更新的性能。
如果你有一些表,它们收集数据且不经常被搜索,则在有必要之
前不要索引它们。(索引可根据需要添加和删除。)  LIKE很慢。一般来说,最好是使用FULLTEXT而不是LIKE。  数据库是不断变化的实体。一组优化良好的表一会儿后可能就面
目全非了。由于表的使用和内容的更改,理想的优化和配置也会
改变。  最重要的规则就是,每条规则在某些条件下都会被打破。 ### 结 必知必会整理到此结束了。

mysql 必知必会整理—数据库的维护[十八]的更多相关文章

  1. 《MySQL必知必会》整理

    目录 第1章 了解数据库 1.1 数据库基础 1.1.1 什么是数据库 1.1.2 表 1.1.3 列和数据类型 1.1.4 行 1.1.5 主键 1.2 什么是SQL 第2章 MySQL简介 2.1 ...

  2. 《MySQL必知必会》学习笔记整理

    简介 此笔记只包含<MySQL必知必会>中部分章节的整理笔记.这部分章节主要是一些在<SQL必知必会>中并未讲解的独属于 MySQL 数据库的一些特性,如正则表达式.全文本搜索 ...

  3. 《MySQL必知必会》官方提供的数据库和表

    数据用于配合<MySQL必知必会>(MySQL Crash Course)这本书使用,配套SQL文件也可在Ben Forta网站下载. Ben Forta网址:http://forta.c ...

  4. MySQL必知必会-官方数据库表及SQL脚本导入生成

    最近在复习SQL语句,看的是MySQL必知必会这本书,但是发现附录中只有表设计,没有表的具体数据.所以在学习相应的语句中体验不是很好,去网上查了数据库的内容,自己慢慢导入到了数据库中.把表放出来作为参 ...

  5. MySQL必知必会(第4版)整理笔记

    参考书籍: BookName:<SQL必知必会(第4版)> BookName:<Mysql必知必会(第4版)> Author: Ben Forta 说明:本书学习笔记 1.了解 ...

  6. 《MySQL 必知必会》读书总结

    这是 <MySQL 必知必会> 的读书总结.也是自己整理的常用操作的参考手册. 使用 MySQL 连接到 MySQL shell>mysql -u root -p Enter pas ...

  7. 《MySQL必知必会》[01] 基本查询

    <MySQL必知必会>(点击查看详情) 1.写在前面的话 这本书是一本MySQL的经典入门书籍,小小的一本,也受到众多网友推荐.之前自己学习的时候是啃的清华大学出版社的计算机系列教材< ...

  8. mysql必知必会系列(一)

    mysql必知必会系列是本人在读<mysql必知必会>中的笔记,方便自己以后查看. MySQL. Oracle以及Microsoft SQL Server等数据库是基于客户机-服务器的数据 ...

  9. mysql必知必会

    春节放假没事,找了本电子书mysql必知必会敲了下.用的工具是有道笔记的markdown文档类型. 下面是根据大纲已经敲完的章节,可复制到有道笔记的查看,更美观. # 第一章 了解SQL## 什么是S ...

  10. mysql学习--mysql必知必会

      上图为数据库操作分类:     下面的操作參考(mysql必知必会) 创建数据库 运行脚本建表: mysql> create database mytest; Query OK, 1 row ...

随机推荐

  1. JAVA 多线程---面经

    线程与进程 提到进程那就要说程序,程序有指令和数据,程序从磁盘加载到内存,cpu获得指令进行执行,其中还会用到各种资源如网络资源,磁盘等.一个程序从磁盘进入内存,就是进程实例的创建. 一个程序可以有多 ...

  2. 幕布 和 xmind 的大纲模式 都很不错

    幕布 和 xmind 的大纲模式 都很不错 xmind 思维导图 ctrl+a 折叠所有子分支 然后就能一级一级展开 最后选择用 xmind的大纲模式,因为免费. 幕布收费,限300个节点,小数据量的 ...

  3. 基于python的socket通信之阿里云socket端口不通的解决方案

    问题描述: 使用python脚本进行socket业务流程,前几天还可以通信很好的,今天突然发现端口不通了.那就排查端口为啥不通了呢? 方案一:设置阿里云安全组 这个网上不少例子,笔者也按照这个操作过, ...

  4. springboot打印启动信息

    打印启动信息 转载自:www.javaman.cn 1 spring Bean实例化流程 基本流程: 1.Spring容器在进行初始化时,会将xml或者annotation配置的bean的信息封装成一 ...

  5. find第二天

    find第二天 1.找出/tmp目录下,属主不是root,且文件名不以f开头的文件 find /tmp ! -user root -a ! -name 'f*' 或者 find /tmp ! -use ...

  6. 记录--再也不用手动改package.json的版本号

    这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 本文的起因是有在代码仓库发包后,同事问我"为什么package.json 里的版本还是原来的,有没有更新?",这个时候 ...

  7. 【福利】JetBrains 全家桶永久免费使用

    Jetbrains系列的IDE公认是最好的集成开发工具,但是收费且挺贵.我们以PhpStorm为例,新用户第一年需要199$,注意是$,还不是人民币,这个价格一上来肯定筛选掉一大批用户.确实好用,所以 ...

  8. FTP上传中文文件,内容乱码

    记录一下: spring boot 程序 ftp上传中文文件,内容乱码. 1.刚开始程序部署在Windows平台上测试,发现上传后的文件内容是乱码,查看文件编码格式是ANSI(Windows下文本文件 ...

  9. CenterNet:Corner-Center三元关键点,检测性能全面提升 | ICCV 2019

    为了解决CornerNet缺乏目标内部信息的问题,提出了CenterNet使用三元组进行目标检测,包含一个中心关键点和两个角点.从实验结果来看,CenterNet相对于CornerNet只增加了少量推 ...

  10. 分享本人依照NOI大纲整理的CSPJ复习资料

    2023 CSP-J 复习文件 考纲 复习好 : 基础知识与编程环境 难度 计算机的基本构成 计算机的组成及功能 - 知乎 (zhihu.com) 操作系统的基本概念与常见操作 操作系统基础知识大汇总 ...