欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

MySQL优化(4):查询缓存

程序员文章站 2022-03-10 19:37:50
查询缓存: MySQL提供的数据缓存QueryCache,用于缓存SELECT查询的结果 默认不开启,需要在配置文件中开启缓存(my.ini/my.cnf) 在[mysqld]段中,修改query_cache_type完成配置: 0:关闭 1:开启,但是默认缓存,需要增加sql-no-cache提示 ......

查询缓存:

mysql提供的数据缓存querycache,用于缓存select查询的结果

默认不开启,需要在配置文件中开启缓存(my.ini/my.cnf)

[mysqld]段中,修改query_cache_type完成配置:

0:关闭

1:开启,但是默认缓存,需要增加sql-no-cache提示,放弃缓存(自动全部存,手动设置哪些不存)

2:开启,但是默认不缓存,需要增加sql-cache提示,执行缓存(不自动存,手动设置存哪些)

配置完毕后重启mysql服务

 

使用命令:

show variables like 'query_cache_type';

如果value显示是demand,代表开启了,是2的方式(通常使用2的方式)

 

设置缓存大小:

配置query_cache_size:

show variables like 'query_cache_size';

查看到value是1048576

修改缓存大小:例如这里修改为64m

set global query_cache_size = 64*1024*1024;

 

如何查询和缓存:

1的情况下直接执行select语句就可以,如果不想缓存,修改语句为:

select sql_no_cache * from student where id=1;

2的情况下需要缓存,那么修改语句为:

select sql_cache * from student where id=1;

 

缓存后,再次执行该select语句耗时接近0秒

 

重置缓存:

reset query cache;

 

缓存失效时间:

如果我们执行这条语句

insert into student (id,user) values (1,'xxx');

那么上面的缓存将会被删除

也就是说,当数据表改动时,基于该数据表的任何缓存,都会被删除,是一个表层面的管理,而不是记录层面的管理

 

动态数据无法被缓存:

比如当前时间,是无法缓存的

select sql_cache *,now() from student;

 

缓存的检索:

缓存的检索是依赖于sql语句的字符串规则,也就是说,修改了大小写或者多加了一个空格,也会失效