如何在mysql中查询缓存(mysql,开发技术)

时间:2024-05-08 02:01:38 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

本篇文章为大家展示了如何在mysql中查询缓存,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

一、查询缓存的实现流程

如何在mysql中查询缓存

二、配置查询缓存

1、查看当前的mysql数据库是否支持查询缓存

SHOWVARIABLESLIKE'have_query_cache';

如何在mysql中查询缓存

2、查看当前mysql是否开启了查询缓存

SHOWVARIABLESLIKE'query_cache_type';

如何在mysql中查询缓存

3、查看查询缓存的占用大小

SHOWVARIABLESLIKE'query_cache_size';

如何在mysql中查询缓存

4、查看查询缓存的状态变量

SHOWSTATUSLIKE'Qcache%';

如何在mysql中查询缓存


参数含义Qcache_free_blocks查询缓存中的可用内存块数Qcache_free_memory查询缓存的可用内存量Qcache_hits查询缓存命中数Qcache_inserts添加到查询缓存的查询数Qcache_lowmen_prunes由于内存不足而从查询缓存中删除的查询数Qcache_not_cached非缓存查询的数量(由于 query_cache_type 设置而无法缓存或未缓存)Qcache_queries_in_cache查询缓存中注册的查询数Qcache_total_blocks查询缓存中的块总数

三、开启查询缓存

MySQL的查询缓存默认是关闭的,需要手动配置参数 query_cache_type , 来开启查询缓存。query_cache_type
该参数的可取值有三个


值含义OFF 或 0查询缓存功能关闭ON 或 1查询缓存功能打开,SELECT的结果符合缓存条件即会缓存,否则,不予缓存,显式指定 SQL_NO_CACHE,不予缓存DEMAND 或 2查询缓存功能按需进行,显式指定 SQL_CACHE 的SELECT语句才会缓存;其它均不予缓存

1、在usr/my.cnf中进行配置(配置文件也可能在/etc/my.cnf)

如何在mysql中查询缓存

2、重启服务

servicemysqlrestart

3、测试

如何在mysql中查询缓存

如何在mysql中查询缓存
如何在mysql中查询缓存

四、查询缓存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中查询缓存的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:jQuery中队列queue()函数怎么使用下一篇:

16 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18