mysql 查询缓存时间设置时间设置时间_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语句的字符串规则,也就是说,修改了大小写或者多加了一个空格,也会失效

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值