MySQL cache功能汇总

数据库 MySQL
此文章主要向大家讲述的是MySQL cache功能,调试笔记,还有MySQL cache的清理的相关内容的描述,下面就是文章的主要内容描述。

以下的文章主要是对MySQL cache功能的描述,同时也对MySQL cache功能的分析,MySQL cache调试笔记与MySQL cache的清理的一些内容的描述,以下就是文章的详细内容描述,望你会有所收获。

MySQL cache功能分析:

 

1 MySQL的cache功能的key的生成原理是:把select语句按照一定的hash规则生成***的key,select的结果生成value,即key=>value。所以对于cache而言,select语句是区分大小写的,也区分空格的。两个select语句必须完完全全一致,才能够获取到同一个cache。

 

 

2 生成cache之后,只要该select中涉及到的table有任何的数据变动(insert,update,delete操作等),相关的所有cache都会被删除。因此只有数据很少变动的table,引入MySQL 的cache才较有意义。关于这方面的测试,可以参考:《Query Cache,看上去很美》一文。

 

 

所以,MySQL的cache功能只适用于下列场合:数据变动较少,select较多的table。

 

 

那么。在复杂的系统中,如何使用MySQLcache功能呢,基本方法如下:

 

配置query_cache_type,同时改写程序。

 

query_cache_type 0 代表不使用缓冲, 1 代表使用缓冲,2 代表根据需要使用。

设置 1 代表缓冲永远有效,如果不需要缓冲,就需要使用如下语句:

 

 

  1. SELECT SQL_NO_CACHE * FROM my_table WHERE ... 

 

如果设置为 2 ,需要开启缓冲,可以用如下语句:

 

 

  1. SELECT SQL_CACHE * FROM my_table WHERE ... 

 

 

So,最简单又可靠的做法是:把query_cache_type设置为2,然后在需要提高select速度的地方,使用:

 

 

  1. SELECT SQL_CACHE * FROM... 

 

的方式进行SELECT。

MySQL cache调试笔记

1 可以使用下列命令开启MySQL的select cache功能:

 

 

  1. SET GLOBAL query_cache_size = 102400000

 

因为当query_cache_size默认为0时,是不开启MySQL cache功能的。

 

 

2 调试:

 

查看cache的设置:

 

 

  1. show variables like '%query_cache%'; 

 

 

性能监控:

 

 

  1. show status like '%Qcache%'; 

 

 

MySQL cache的清理:

 

可以使用FLUSH QUERY CACHE语句来清理查询缓存碎片以提高内存使用性能。该语句不从缓存中移出任何查询。

 

RESET QUERY CACHE语句从查询缓存中移出所有查询。FLUSH TABLES语句也执行同样的工作。

 

以上的相关内容就是对MySQL cache功能的介绍,望你能有所收获。

【编辑推荐】

  1. 安装MySQL-python的实际操作步骤
  2. PHP和MySQL存储过程的实例演示
  3. 解决MySQL无法远程访问的3方案
  4. MySQL 常用语句的基本用法的介绍
  5. MySQL数据库文件其具体的存放位置简述

 

责任编辑:佚名 来源: cnblogs
相关推荐

2011-04-12 10:30:35

Windows 8

2014-03-10 17:44:43

Windows 8.1

2011-05-16 10:16:19

MYSQL出错代码

2010-06-11 16:41:51

MySQL启动

2010-07-05 09:07:42

2011-09-07 15:28:35

Windows 8

2010-05-24 10:42:33

MySQL heap

2010-05-11 10:36:13

MySQL索引类型

2010-05-13 11:05:56

2010-05-21 18:20:43

MySQL常用技巧

2010-05-20 11:36:25

MySQL 修改密码

2013-10-08 17:16:37

Windows 8.1IE11

2024-03-06 16:25:30

iOS 17.4苹果

2011-07-06 11:33:18

Windows 8

2009-04-08 18:05:53

Vmwareesx虚拟化

2009-04-08 15:06:01

2010-05-13 13:27:23

2014-03-10 10:24:01

MySQLMySQL优化

2010-05-28 19:12:09

MySQL使用方法

2010-05-11 19:18:44

点赞
收藏

51CTO技术栈公众号