Unknown system variable 'query_cache_size'

本来想学习一下mysql的查询缓存,但是在关闭缓存时却出现以下问题:
在这里插入图片描述
后来才发现自己的Mysql版本是8.0.13,而Mysql 8.0以后就彻底没有查询缓存这个功能了。
【补充】

之前的版本中Mysql拿到了一个查询请求后,会先到查询缓存中看看之前是不是执行过这条语句。如果查询缓存开启了的话,之前执行过的语句及其结果会以key-value对的形式,被直接缓存在内存中,其中key是查询的语句,value是查询的结果。如果新查询请求能够直接在这个缓存中找到key,那么这个value就会被直接返回给客户端。所以如果查询命中缓存,Mysql不需要执行后面的复杂操作,就可以直接返回结果,这个效率会很高。

但是查询缓存的失效会非常频繁,只要有对一个表的更新,这个表上所有的查询缓存都会被清空。因此很可能你费劲地把结果存起来,还没使用呢,就被一个更新全清空了。对于频繁更新的数据库来说,查询缓存的命中率会非常低。除非你的业务就是有一张静态表,很长时间才会更新一次。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值