大家好,我是考100分的小小码 ,祝大家学习进步,加薪顺利呀。今天说一说MySQL优化(4):查询缓存,希望您对编程的造诣更进一步.
查询缓存:
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";
代码100分
如果VALUE显示是DEMAND,代表开启了,是2的方式(通常使用2的方式)
设置缓存大小:
配置query_cache_size:
代码100分SHOW VARIABLES LIKE "query_cache_size";
查看到VALUE是1048576
修改缓存大小:例如这里修改为64M
SET GLOBAL query_cache_size = 64*1024*1024;
如何查询和缓存:
1的情况下直接执行SELECT语句就可以,如果不想缓存,修改语句为:
代码100分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语句的字符串规则,也就是说,修改了大小写或者多加了一个空格,也会失效
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/9590.html