如何在mysql中查询缓存
导读:本文共2531字符,通常情况下阅读需要8分钟。同时您也可以点击右侧朗读,来听本文内容。按键盘←(左) →(右) 方向键可以翻页。
摘要:本篇文章为大家展示了如何在mysql中查询缓存,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、查询缓存的实现流程二、配置查询缓存1、查看当前的mysql数据库是否支持查询缓存SHOWVARIABLESLIKE'have_query_cache';2、查看当前mysql是否开启了查询缓存SHOWVARIABLESLIKE'query... ...
目录
(为您整理了一些要点),点击可以直达。本篇文章为大家展示了如何在mysql中查询缓存,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
一、查询缓存的实现流程
二、配置查询缓存
1、查看当前的mysql数据库是否支持查询缓存
SHOWVARIABLESLIKE'have_query_cache';
2、查看当前mysql是否开启了查询缓存
SHOWVARIABLESLIKE'query_cache_type';
3、查看查询缓存的占用大小
SHOWVARIABLESLIKE'query_cache_size';
4、查看查询缓存的状态变量
SHOWSTATUSLIKE'Qcache%';
三、开启查询缓存
MySQL的查询缓存默认是关闭的,需要手动配置参数 query_cache_type , 来开启查询缓存。query_cache_type
该参数的可取值有三个
1、在usr/my.cnf中进行配置(配置文件也可能在/etc/my.cnf)
2、重启服务
servicemysqlrestart
3、测试
四、查询缓存SELECT选项
可以在SELECT语句中指定两个与查询缓存相关的选项
SQL_CACHE : 如果查询结果是可缓存的,并且 query_cache_type 系统变量的值为ON或 DEMAND ,则缓存查询 结果 。
SQL_NO_CACHE : 服务器不使用查询缓存。它既不检查查询缓存,也不检查结果是否已缓存,也不缓存查询结果
SELECTSQL_CACUEid,nameFROMcustomer;SELECTSQL_NO_CACHEid,nameFROMcustomer;
五、查询缓存失效现象
1、SQL语句不一致
要想命中缓存,查询的SQL语句必须一致
SQL1:selectcount(*)fromtb_item;SQL2:selectcount(*)fromtb_Item;
2、查询语句有一些不确定的值
SQL1:select*fromtb_itemwhereupdatetime<now()limit1;SQL2:selectuser();SQL3:selectdatabase();
3、不使用任何表查询语句
select'A';
4、查询mysql、information_schema或performance_schema数据库中的表
select*frominformation_schema.engines;
5、在存储的函数、触发器或事件主体内执行的查询
如题
6、表更改导致缓存删除
如果表更改,则使用该表的所有高速缓存查询都将变为无效并从高速缓存中删除。这包括使用 MERGE 映射到 已更改表的表的查询。一个表可以被许多类型的语句,如被改变 INSERT, UPDATE, DELETE, TRUNCATE TABLE, ALTER TABLE, DROP TABLE,或 DROP DATABASE 。
上述内容就是如何在mysql中查询缓存,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注亿速云行业资讯频道。
如何在mysql中查询缓存的详细内容,希望对您有所帮助,信息来源于网络。