推荐15条MySQL改善经验,让系统更稳定

数据库 MySQL
像 NOW() 和 RAND() 或是其它的诸如此类的SQL函数都不会开启查询缓存,谨慎使用;MySQL数据库引擎会在查找到一条数据后停止搜索,而不是继续往后查询下一条符合条件的数据记录。

推荐15条MySQL改善经验,让系统更稳定

1、 为查询缓存优化查询

像 NOW() 和 RAND() 或是其它的诸如此类的SQL函数都不会开启查询缓存,谨慎使用

2、EXPLAIN 我们的SELECT查询(可以查看执行的行数)

可以让我们找到潜在的性能问题

3、当只要一行数据时使用LIMIT 1

MySQL数据库引擎会在查找到一条数据后停止搜索,而不是继续往后查询下一条符合条件的数据记录。

4、为搜索字段建立索引

在识别度高的列上建立正确的索引,以提升性能

5、在Join表的时候使用相当类型的列,并将其索引

关联表的关键字段,类型一致,字符集一致,才能提高性能,否则无法使用它们的索引

6、千万不要 ORDER BY RAND ()

执行RAND()函数(很耗CPU时间),会让你的数据库的性能呈指数级的下降

7、 避免SELECT *

从数据库里读出越多的数据,那么查询就会变得越慢。

8、永远为每张表设置一个ID

我们应该为数据库里的每张表都设置一个ID做为其主键,而且***的是一个INT型的(推荐使用UNSIGNED),并设置上自动增加的 AUTO_INCREMENT标志。

9、可以使用ENUM 而不要VARCHAR

ENUM 类型是非常快和紧凑的。在实际上,其保存的是 TINYINT,但其外表上显示为字符串。

10、尽可能的使用NOT NULL

如果不是特殊情况,尽可能的不要使用NULL。在MYSQL中对于INT类型而言,EMPTY是0,而NULL是空值。而在Oracle中 NULL和EMPTY的字符串是一样的。NULL也需要占用存储空间,并且会使我们的程序判断时更加复杂。现实情况是很复杂的,依然会有些情况下,我们需要使用NULL值。

11、固定长度的表会更快

表中没有如下类型的字段: VARCHAR,TEXT,BLOB。只要我们包括了其中一个这些字段,那么这个表就不是“固定长度静态表”了,这样,MySQL 引擎会用另一种方法来处理。 固定长度的表会提高性能,因为MySQL搜寻得会更快一些,因为这些固定的长度是很容易计算下一个数据的偏移量的,所以读取的自然也会很快。

12、垂直分割

“垂直分割”是一种把数据库中的表按列变成几张表的方法,这样可以降低表的复杂度和字段的数目,从而达到优化的目的。

13、拆分打的DELETE或INSERT语句

这两个操作是会锁表的

14、越小的列会越快

对于大多数的数据库引擎来说,硬盘操作可能是最重大的瓶颈。越小的列消耗的io资源越少

15、选择正确的存储引擎

MyISAM是MYSQL5.5版本以前默认的存储引擎,基于传统的ISAM类型,支持B-Tree,全文检索,但是不是事务安全的,而且不支持外键。不具有原子性。支持锁表。

InnoDB是事务型引擎,支持ACID事务(实现4种事务隔离机制)、回滚、崩溃恢复能力、行锁。以及提供与Oracle一致的不加锁的读取方式。InnoDB存储它的表和索引在一个表空间中,表空间可以包含多个文件。 

责任编辑:庞桂玉 来源: 今日头条
相关推荐

2012-06-15 14:02:51

火狐设置

2016-12-30 16:21:55

数据中心

2018-04-09 08:36:53

敏捷开发云安全基础设施

2020-12-19 10:45:08

Python代码开发

2017-07-03 16:42:09

Docker中国镜像

2012-04-25 23:00:05

App Store

2012-07-05 10:18:03

HTML5

2016-11-01 11:33:34

无线网络WIFI

2009-04-09 09:05:47

2015-03-17 09:34:57

PHP响应式网页设计网页设计建议

2017-06-07 14:34:48

数据DB修改

2013-07-12 10:44:54

2015-05-18 14:49:27

2018-05-14 15:55:28

LinuxBash

2011-07-21 09:29:49

Windows系统工具免费工具

2021-04-26 23:14:25

4G5G手机

2021-07-18 08:18:01

Windows 11操作系统微软

2018-07-03 15:07:59

iOS 12苹果iPhone

2019-10-08 10:25:00

MySQL数据库DNS
点赞
收藏

51CTO技术栈公众号