Mysql Query Cache的基本原理

Query Cache是根据SQL语句来cache的,一个SQL查询如果以select开头,那么MySQL将尝试对其进行缓存

每个Cache都是以完整的SQL语句作为key来存的,两个SQL语句,只要相差哪怕是一个字符(例如大小写不一样;多一个空格等),那么这两个SQL将使用不同的一个CACHE

无法缓存的情况 1)查询语句中加了SQL_NO_CACHE参数 2)查询语句中含有获得值的函数,包涵自定义函数,如:CURDATE()、GET_LOCK()、RAND()、CONVERT_TZ等 3)对系统数据库的查询:mysql、information_schema 4)查询语句中使用SESSION级别变量或存储过程中的局部变量 5)查询语句中使用了锁 LOCK IN SHARE MODE、FOR UPDATE的语句 6)查询语句中类似SELECT …INTO 导出数据的语句 7)对临时表的查询操作 8)存在警告信息的查询语句 9)不涉及任何表或视图的查询语句 10)某用户只有列级别权限的查询语句

原文发布于微信公众号 - 性能与架构(yogoup)

原文发表时间:2015-10-20

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏lgp20151222

技术无关 自己写的项目 一些数据库的想法

+----------+--------------+------+-----+---------+----------------+ | Field    |...

8230
来自专栏数据和云

层层升入:SQL极限调优之一次更新操作的N种优化可能

杨廷琨,网名 yangtingkun 云和恩墨技术总监,Oracle ACE Director,ACOUG 核心专家 最近进行了一次更新操作,整个处理和优化的过...

32080
来自专栏C/C++基础

MySQL如何将select子查询结果横向拼接后插入数据表中

除了最后一列默认是当前时间戳,每一列的结果都是一个select查询结果。如何将查询的结果合并成一条记录插入到上面的数据表中呢?网上也没有确切的答案,摸索了很久,...

26320
来自专栏资深Tester

SQL系列之DDL/DCL语言

25560
来自专栏JAVA后端开发

通用数据级别权限的框架设计与实现(2)-数据权限的准备工作

查看上篇文章通用数据级别权限的框架设计(1)-相关业务场景的分析",我们要继续做一些准备工作。

13240
来自专栏撸码那些事

MySQL——索引实现原理

在MySQL中,索引属于存储引擎级别的概念,不同存储引擎对索引的实现方式是不同的,本文主要讨论MyISAM和InnoDB两个存储引擎的索引实现方式。

8720
来自专栏Linyb极客之路

深入理解MySQL索引原理和实现——为什么索引可以加速查询?

说到索引,很多人都知道“索引是一个排序的列表,在这个列表中存储着索引的值和包含这个值的数据所在行的物理地址,在数据十分庞大的时候,索引可以大大加快查询的速度,这...

18330
来自专栏Jed的技术阶梯

Hive窗口函数04-LAG、LEAD、FIRST_VALUE、LAST_VALUE

Hive窗口函数LAG、LEAD、FIRST_VALUE、LAST_VALUE入门

37710
来自专栏数据库

数据库的完整性

导读: 本文深入的介绍了数据库的完整性. O、 数据库的完整性(总体概述) 一、实体完整性 二、参照完整性 三、用户定义完整性 O、数据库的完整性 数据的正确性...

22690
来自专栏左瞅瞅,右瞅瞅

SaltStack——小叙(远程执行)

想要返回结果返回mysql 库中,返回是salt-minion 返回,所有的salt-minion 需要安装Mysql-python 依赖包:

21940

扫码关注云+社区

领取腾讯云代金券