前言

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

正文

像所有数据一样,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. 通过python获取SSL证书到期时间

    在前面的文章中曾介绍过如何通过openssl命令获取SSL证书的到期时间:通过zabbix监控ssl证书到期时间. 有人反馈实践中这种方式存在缺陷,可能会出现部分域名证书无法获取的情况,报错如下: 1 ...

  2. left jon连接查询踩坑记

    项目开发中经常会使用到多张表进行关联查询,比如left join关联查询. 如果有一张表A和一张表B,查询语句 SELECT a.*,b.name from A a left join B b On ...

  3. 清除 gitee.io 页面强缓存 Chrome浏览器 F12 找到页面 右键 Clear browser cache

    清除 gitee.io 页面强缓存 Chrome浏览器 F12 找到页面 右键 Clear browser cache

  4. 虚拟机 centos web nodejs服务 外网映射

    虚拟机 centos web nodejs服务 外网映射 起因 为了不买云服务器也是拼了 1. 安装虚拟机 VMware-Workstation-Lite-15.5.1-15018445精简官方中文安 ...

  5. PBKDF2算法:保障密码安全的利器

    PBKDF2算法起源: PBKDF2(Password-Based Key Derivation Function 2)算法是一种基于密码的密钥派生函数,最初由RSA实验室的密码学家提出,用于从密码中 ...

  6. Vuejs右键弹出菜单

    一.安装 npm install @xunlei/vue-context-menu 二.修改main.js import VueContextMenu from '@xunlei/vue-contex ...

  7. Linux_Centos 增加中文字体支持

    宋体黑体为例 1.安装字体库 在CentOS 4.x开始用fontconfig来安装字体库,所以输入以下命令即可: sudo yum -y install fontconfig 这时在/usr/sha ...

  8. HDFS Balancer负载均衡器

    目录 1.背景 2.什么是平衡 2.1 每个DataNode的利用率计算 2.2 集群的利用率 2.3 平衡 3.hdfs balancer语法 4.运行一个简单的balance案例 4.1 设置平衡 ...

  9. archlinux xfce禁用Alt+F打开终端文件菜单

    参照:https://superuser.com/questions/456024/how-to-disable-alt-f-shortcut-binding-from-file-menu-acces ...

  10. 【已解决】IDEA项目启动时Maven报错:Downgrade Maven to version 3.8.1 or earlier in settings

    报错场景如下: Possible solutions: Check that Maven pom files not contain http repository http://mvn.gt.ige ...