• 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';

    如果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语句的字符串规则,也就是说,修改了大小写或者多加了一个空格,也会失效

  • 相关阅读:
    Documentation | AnsibleWorks
    Salt Stack 官方文档翻译
    OSNIT_百度百科
    内心觉得自己会是一个还比较厉害的产品经理,对于新产品的整合上
    知方可补不足~UPDLOCK更新锁的使用
    MongoDB学习笔记~环境搭建
    压力测试~一套完整的压力测试项目文档
    压力测试~测试工具的使用
    不说技术~关于创业一点想法
    HTML5 Canvas 填充与描边(Fill And Stroke)
  • 原文地址:https://www.cnblogs.com/miaoweiye/p/12519467.html
Copyright © 2020-2023  润新知