mysql基础(五)查询缓存

缓存的有缺点
    1、如果命中缓存,直接从缓存中返回,减少分析和执行SQL语句的过程,提高查询效率
    2、缓存会带来额外的开销,如果开启缓存的代价大于不开启缓存的代价则不建议开启缓存

    
缓存的开销
    1、读查询在开始之前会先检查查询缓存
    2、若某个读查询可以被缓存且未被缓存,那么当完成执行后,MySQL会将其结果存入查询缓存
    3、对写操作也有影响,因为当写入数据时,MySQL必须将对应表的所有缓存都设置失效,
    这在缓存内存较大时将导致很大的系统消耗,所以缓存内存并不是越大越好

    
mysql查询缓存
    1、用于保存查询语句返回的结果,命中时,MySQL会立即返回结果,省去解析、优化和执行等步骤
   2、MySQL保存结果于缓存中,对select语句做hash计算,计算的结果作为key,查询结果作为value
  3、mysql查询缓存对大小写敏感,所以使用SQL时尽量使用同一种风格
    
  
不会被缓存的语句
  1、不确定的数据,不会缓存,如now(),current_time()等
  2、若查询SQL中包含用户自定义函数,存储函数,用户变量,临时表,mysql库中系统表
  3、SQL中包含字段权限
  
  
与缓存相关的服务器变量
mysql> SHOW VARIABLES LIKE ‘query%‘;		#查看和查询缓存相关的系统变量
    query_cache_type: 是否打开缓存
	OFF: 关闭    ON: 打开    DEMAND: 只有明确写了SQL_CACHE的查询才会写入缓存
    query_cache_size: 缓存使用的总内存空间大小,单位是字节,这个值必须是1024的整数倍
    query_cache_min_res_unit: 分配的最小内存块大小,太大可能导致内存碎片,太小可能导致频繁请求内存
    query_cache_limit: 能够缓存的最大结果,如果超出这个大小则清处已经缓存的数据
    query_cache_wlock_invalidate: 如果某个数据表被锁住,是否仍然从缓存中返回数据,OFF:表示可以返回

mysql> SHOW STATUS LIKE ‘%qcache%‘;		#查看缓存状态
    Qcache_free_blocks		#缓存池中空闲块的个数
    Qcache_free_memory		#缓存中空闲内存量
    Qcache_hits			#缓存命中次数
    Qcache_inserts		#缓存写入次数
    Qcache_lowmen_prunes	#因内存不足删除缓存次数
    Qcache_not_cached 		#查询未被缓存次数
    Qcache_queries_in_cache 	#当前缓存中缓存的SQL数量
    Qcache_total_blocks 	#缓存的总内存块

是否使用缓存
    1. 通过缓存命中率判断, 缓存命中率 = 缓存命中次数 (Qcache_hits) / 查询次数 (Com_select)
    2. 通过缓存写入率, 写入率 = 缓存写入次数 (Qcache_inserts) / 查询次数 (Com_select)
    3. 通过 命中-写入率 判断, 比率 = 命中次数 (Qcache_hits) / 写入次数 (Qcache_inserts)
	3:1则算是查询缓存有效,而最好能够达到10:1

    mysql> SHOW GLOBAL STATUS LIKE ‘com_select‘;		#查看查询次数

分析和配置查询缓存

时间: 2024-12-06 12:21:40

mysql基础(五)查询缓存的相关文章

MySQL 权限和查询缓存

MySQL 权限和查询缓存 ================================================================================ 概述: ================================================================================ MySQL用户和权限管理    1.权限类别 ★用户账号:[email protected] user:账户名称: host:此账户可通过哪

mysql query cache 查询缓存

查看本博文,并进行验证(验证结果与博文一致): https://blog.csdn.net/carmazhao/article/details/7088530 mysql默认是开启查询缓存的. 设置查询缓存的内存大小: 查询缓存的命中次数查询: 再执行相同sql4次: 插入数据后: 紧接着执行相同的sql,没有命中查询缓存 插入数据后,第二次执行相同的sql,命中查询缓存 原文地址:https://www.cnblogs.com/hblthink/p/8799229.html

数据库MySQL/mariadb知识点——查询缓存

查询的执行路径 SQL语句 查询缓存 解析器 解析树 预处理 查找最好的查询路径 查询优化SQL语句 执行计划 API调用存储引擎 调用数据,返回结果 缓存SELECT操作或预处理查询的结果集和SQL语句,当有新的SELECT语句或预处理查询语句请求,先去查询缓存,判断是否存在可用的记录集,判断标准:与缓存的SQL语句,是否完全一样,区分大小写. 不需要对SQL语句做任何解析和执行,当然语法解析必须通过在先,直接从Query Cache中获得查询结果,提高查询性能 查询缓存的判断规则,不够智能,

MySQL/MariaDB的查询缓存

查询缓存: 缓存的数据:k/v,即键值对: key:查询语句的hash值: value:查询语句的查询结果: 判断缓存是否命中标准: 通过整个查询语句的hash值的比较,完全相同则命中: 有些查询结果是不能被缓存的: 要查询的数据库中可能包含敏感信息 在查询语句中包含有用户自定义的函数(UDF): 存储函数: 用户自定义变量: 对于临时表发起的查询请求: 包含列级别授权的查询: 有着不确定结果值的mysql的内建函数: 如:NOW(), CURRENT_DATE(), CURRENT_TIME(

mybatis入门基础(八)-----查询缓存

阅读目录 一.什么是查询缓存 二.一级缓存 三.二级缓存 回到顶部 一.什么是查询缓存 mybatis提供查询缓存,用于减轻数据压力,提高数据库性能. mybaits提供一级缓存,和二级缓存. 1.1. 一级缓存是sqlSession级别的缓存.在操作数据库时需要构造sqlSession对象,在对象中有一个数据结构(HashMap),用于存储缓存数据.不同的sqlSession之间的缓存 区域(HashMap)是互不影响的. 1.2. 二级缓存是mapper级别的缓存,多个sqlSession去

MYSQL基础02(查询)

查询是很大的一块,所以这里我只会写mysql的特点,就我目前使用的情况,MYSQL对标准SQL是比较支持,如果是新手的话,建议去w3school 学习标准SQL. 1.DUAL DUAL是一个虚拟表,即该表是不存在的,用于直接select 标量时,使语句看起来符合sql规范 -- MSSQL select 1,'A' -- Oracle中dual 不可缺少 select 1,'A' from DUAL -- mysql 以下2种格式都支持 select 1,'A'; select 1,'A' f

Mysql 基础 高级查询

在西面内容中    car  和  nation   都表示 表名 1.无论 高级查询还是简单查询   都用  select.. from..语句   from  后面 加表名  可以使一张表也可以是多张表   表和表之间用逗号隔开 2. 简单查询和高级查询 不是 独立的   高级查询里面 同样可以用到 简单查询   3.简单查询与复杂查询的联系: 简单查询里面 后面的条件 未知时 需要用另一个 查询来代替  这样就变成了高级查询 4.链接查询  和  联合查询的区别:1. 链接查询 连接两张以

MYSQL基础五--数据修改

1.添加单列 ALTER TABLE tab_red(表名)ADD age(列名) INT(列类型)约束 {FIRST|AFTER  dname(在dname列之后)}: ALTER TABLE tab_red ADD age INT NOT NULL DEFAULT 10; 2.添加多列 ALTER TABLE tab_red(表名)ADD (dname varchar(30),age int unsigned); 添加多列不能设置列的位置,不能放在第一列和某一列之间.只能默认在最后. 3.删

mysql 基础 交集查询

原文地址:https://www.cnblogs.com/angdh/p/11538018.html

《高性能MySQL》读书笔记--查询缓存

1.MySQL查询缓存 很多数据库产品都能够缓存查询的执行计划,对于相同类型的SQL就可以跳过SQL解析和执行计划生成阶段.MySQL还有另一种不同的缓存类型:缓存完整的SELECT查询结果,也就是"查询缓存". 查询缓存系统会跟踪查询中涉及的每个表,如果这些表发生变化,那么和这个表相关的所有的缓存数据都将失效. 查询缓存对应用程序是完全透明的.应用程序无须关心MySQL是通过查询缓存返回的结果还是实际执行返回的结果. 另外,随着现在的通用服务器越来越强大,查询缓存可能是一个影响服务器