文章详情

短信预约信息系统项目管理师 报名、考试、查分时间动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MySQL优化(4):查询缓存

2018-07-13 20:57

关注

MySQL优化(4):查询缓存

查询缓存:

MySQL提供的数据缓存QueryCache,用于缓存SELECT查询的结果

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

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

0:关闭

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

开启,但是默认不缓存,需要增加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语句的字符串规则,也就是说,修改了大小写或者多加了一个空格,也会失效

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯