`
eoasis
  • 浏览: 76859 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

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功能的介绍,望你能有所收获。

 

转自:http://database.51cto.com/art/201006/203406.htm

分享到:
评论

相关推荐

    MySQL thread_cache和table_cache详解

    THREAD_CACHE MySQL里面为了提高客户端请求创建连接过程的性能,提供了一个连接池也就是 Thread_Cache池,将空闲的连接线程放在连接池中,而不是立即销毁.这样的好处就是,当又有一个新的请求的时候,mysql不会立即去创建...

    Mysql面试题汇总资料

    Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql面试题汇总Mysql...

    Mysql转oracle工具

    数据库 Mysql转oracle sql脚本转oracle脚本

    MySql转换成Oracle工具

    Convert Mysql to Oracle 功能特点 可以转换所有的Mysql字段类型 支持所有版本的Mysql 可以将数据合并到已经存在的ORACLE表中 非常容易使用的向导模式 支持所有版本的Mysql字符集 对超大数据表的导出进行了...

    mysql阳历转农历实现逻辑代码

    mysql阳历转农历的mysql 函数mysql阳历转农历的mysql 函数mysql阳历转农历的mysql 函数

    mysql 数据库转 oracle

    mysql数据库转oracle工具,解压即用,支持表结构转换a

    mysql frm转sql

    MySqlFrm.exe是c#版本的frm转sql工具,需要.net 4.0与mysql环境,CMD命令行如下: mysqlfrm <username> <password> <port> 例如: mysqlfrm root pass 3306 c:\dbcopy 会将c:\dbcopy目录下所有的frm转换为...

    MySQL函数-数字转换为大写中文

    MySQL函数 数字转中文 非金额 处理数据类型 decimal(21,6)

    pbootcms数据sqlite转mysql数据库

    sqlite数据库转mysql数据库

    Mysql中文汉字转拼音的实现(每个汉字转换全拼)

    主要介绍了Mysql中文汉字转拼音的实现,并且每个汉字会转换全拼,使用Mysql自定义函数实现,需要的朋友可以参考下

    Mysql转Oracle软件 DBMover for Mysql to Oracle

    Dbmover for Mysql to Oracle 是高效的将Mysql导入到Oracle数据库的工具。 使用DBMover可以灵活定义Mysql和Oracle之间表和字段的对照关系,也可以在DBMover创建一个查询,把查询结果当作源表转入到Oracle中。 ...

    MySQL Migration Toolkit 数据库转换工具

    Access-to-MySQL Access数据库转MySQL数据库 DBF-to-MySQL DBF数据库转MySQL数据库 Excel-to-MySQL Excel数据库转MySQL数据库 MSSQL-to-MySQL MSSQL数据库转MySQL数据库 SQL Server数据库转MySQL数据库 MySQL-to-...

    mysql转换postgresql工具

    国外大牛写的一个mysql数据库转换postgresql的脚本。亲试可以无错误运行。

    mysql语句转postgres的工具

    从mysql数据库迁移到postgres数据库转换ddl语句的工具,添加了自动更新时间的触发器。

    mysql oracle 阿拉伯数字转中文数字

    mysql oracle 阿拉伯数字转中文数字, 亲测可用.找了很长时间才找到,

    mysql转word文档

    在本地电脑---管理工具----数据源(ODBC),创建一个本地mysql数据库,然后在word工具里面,连接刚创建的数据源,然后选择要转文档的数据库。

    mysql常见面试题汇总

    mysql常见面试题汇总mysql常见面试题汇总mysql常见面试题汇总mysql常见面试题汇总mysql常见面试题汇总mysql常见面试题汇总mysql常见面试题汇总mysql常见面试题汇总mysql常见面试题汇总mysql常见面试题汇总mysql常见...

    两个软件奥mysql转oracle oracle转mysql

    Convert Mysql to Oracle功能特点 可能转换所有的Mysql字段类型 支持所有版本的Mysql 可以将数据合并到已经存在的ORACLE表中 非常容易使用的向导模式 支持所有版本的Mysql字符集 对超大数据表的导出进行了优化处理

    MySQL to Oracle MySQL 转 Oracle亲自测试,好用

    MySQL to Oracle MySQL 转 Oracle亲自测试,好用

Global site tag (gtag.js) - Google Analytics