mysql查询缓存
来源:互联网 发布:mysql数据定义语言 编辑:程序博客网 时间:2024/06/12 21:01
通过查询缓存提高MYSQL的查询性能
1.显然,这对于频繁更新的表,查询缓存是不适合的,而对于一些不常改变数据且有大量相同sql查询的表,查询缓存会节约很大的性能。(mysql4.0.1可以使用查询缓存)
2.查询缓存区分大小写 如:SELECT * from table1 与SELECT * FROM table1是不同的。
3.而且查询缓冲并不自动处理空格,因此,在写SQL语句时,应尽量减少空格的使用,尤其是在SQL首和尾的空格(因为,查询缓冲并不自动截取首尾空格)。如:SELECT * FROM table1 和 SELECT * FROM table1(带有空格)那么执行两条语句时,最后一条相同的SQL语句不会使用查询缓存。
4.虽然不设置查询缓冲,有时可能带来性能上的损失,但有一些SQL语句需要实时地查询数据,或者并不经常使用(可能一天就执行一两次)。这样就需要把 缓冲关了。当然,这可以通过设置query_cache_type的值来关闭查询缓冲,但这就将查询缓冲永久地关闭了。在MySQL 5.0中提供了一种可以临时关闭查询缓冲。
(1) SELECT SQL_NO_CACHE field1, field2 FROM TABLE1
以上的SQL语句由于使用了SQL_NO_CACHE,因此,不管这条SQL语句是否被执行过,服务器都不会在缓冲区中查找,每次都会执行它。
我们还可以将my.ini中的query_cache_type设成2,这样只有在使用了SQL_CACHE后,才使用查询缓冲。
(2) SELECT SQL_CALHE * FROM TABLE1
二、什么情况可以命中查询缓存?????
1.在检查缓存的时候,MySQL 不会对语句进行解析、正则化或者参数化,它精确地使用客户端传来的查询语句和其他数据(不同的数据库、不同的协议版本或者不同 默认字符集的查询,mysql也会认为这是不同的查询sql,会分别进行查询缓存)。只要字符大小写、空格或者注释有一点点不同,查询缓存就认为这是一个不同的查询.
2.查询缓存不会存储有不确定结果的查询。因此,任何一个包含不确定函数(比如NOW()或CURRENT_DATE())的查询不会被缓存。同样地,CURRENT_USER()或CONNECTION_ID()这些由不同用户执行,将会产生不同的结果的查询也不会被缓存。事实上,查询缓存不会缓存引用了用户自定义函数、存储函数、用户自定义变量、临时表、mysql 数据库中的表或者任何一个有列级权限的表的查询
3.查询必须是完全相同的(逐字节相同)才能够被认为是相同的。另外,同样的查询字符串由于其它原因可能认为是不同的。使用不同的数据库、不同的协议版本或者不同 默认字符集的查询被认为是不同的查询并且分别进行缓存。
三。查询缓存的性能消耗
1.读取查询在开始之前必须要检查缓存。
2.如果查询是可以被缓存的,但是不在缓存中,那么在产生结果进行保存会带来一些额外的开销。写入数据的查询也会有额外的开销,因为它必须使缓存中相关的数据表失效
show variables like '%query_cache%';(查看是否开启了缓存等参数)
FLUSH QUERY CACHE(会对缓存中的碎片进行整理,从而得到一个空闲块)
show status LIKE 'qcache%'(查询缓存的使用情况)
- 关于MYSQL 查询缓存
- mysql 查询缓存
- MySQL 查询缓存数据库
- MySQL查询缓存优化
- MySQL清除查询缓存
- mysql查询缓存
- MySQL查询缓存状态
- MySQL查询缓存设置
- mysql的查询缓存
- mysql查询缓存
- mysql查询缓存
- mysql 查询缓存 query_cache_type
- MySql查询缓存机制
- MySql:查询缓存机制
- MySQL 查询缓存
- MySQL 查询缓存
- mysql无缓存查询
- Mysql 查询缓存
- 傅里叶的开篇
- BZOJ 4318: OSU! 期望dp
- android自定义控件-----自定义数字价格键盘
- Android消息机制基本原理
- [BZOJ1898][ZJOI2005]沼泽鳄鱼(矩阵乘法)
- mysql查询缓存
- Java基础——Servlet(五)
- FreeRTOS任务API函数的使用
- 外观模式
- 学习Opencv(一)
- Centos7-1611 安装LAMP
- 对MapReduce一些理解
- 1018. 锤子剪刀布 (20)
- leetcode 15. 3Sum