当前位置:首页 > 数据库 > mysql的查询缓存

mysql的查询缓存

2022年09月16日 22:13:29数据库6

     提高单台节点的性能无外乎就那么几种方式,缓存是首当其冲的,因为内存的性能比磁盘高的太多。缓存也是一种典型的空间换时间的策略

     缓存的实现也有太多的方式,从静态页面缓存到服务端动态缓存,再到数据库级别缓存等等。随着大数据的到来也产生了太多太多的内存数据库。

     缓存的工具也多种多样,随口一说就能说出很多,像Redis,Memcached,Hbase等,就连MySQL也有一个memory引擎数据就是直接存储到内存中,所以缓存无处不在。

     缓存的形式也多种多样,上面说的算是比较传统的缓存,其实各种的消息队列何尝又不是一种缓存机制。

     缓存也是有缺陷,既然是缓存,那么针对的对象都是一些不变或者变化不大的对象,如果数据是经常变化的那么对其缓存反而适得其反。

     说了那么多了,下面就说说MySQL的查询缓存吧,MySQL的查询缓存是MySQL内置的一种缓存机制,可以针对sql进行缓存。比如我们发送select * from mysql.user这么一个查询,MySQL首先检索内存中是否有数据并且数据是否过期,如果没有数据或者数据已经过期就去数据库中查找,如果有数据并且没有过期就直接返回数据。对于sql的匹配规则非常简单,就是字符串的比较,只要字符串相同,那么就认为是同一个查询。这里的字符串相同并不是表示sql语义相同,而是查询的sql字符串相同,空格也不行。MySQL的缓存是对全部的sql有效的, 也就是说一旦开启了查询缓存,那么对所有的sql查询默认都是开启的。我们会有很多变化的数据,其实是不希望开启查询缓存的,这个MySQL也给我们想到了,就是在sql中加入 sql_no_cache  比如,select sql_no_cache * from mysql.user这样,MySQL就会绕过缓存直接从库里查找数据。另外还有一个需要注意的,比如我们在sql中使用了now()这样的函数,MySQL是不会给我们缓存的。

     先来看一下有没有开启查询缓存

    mysql的查询缓存 _ JavaClub全栈架构师技术笔记

     开启查询缓存的方式也非常简单,在my.cnf配置文件中设置上面的关于查询缓存的变量就可以了,下面具体说说每个变量的含义。

query_caceh_type 是否开启查询缓存

 

0 表示不开启查询缓存,
1 表示始终开启查询缓存(不要缓存使用sql_no_cache) ,
2 表示按需开启查询缓存 (需要缓存使用 sql_cache)。

query_cache_size 给缓存分配的最大内存空间 

 

对于查询缓存的一些操作。

  1. FLUSH QUERY CACHE; // 清理查询缓存内存碎片。
  2. RESET QUERY CACHE; // 从查询缓存中移出所有查询。
  3. FLUSH TABLES; //关闭所有打开的表,同时该操作将会清空查询缓存中的内容。

 

缓存虽然能够大幅度提高性能,但用起来也要慎重,一旦用不好,反而会适得其反。

作者:jhappyfly
来源链接:https://blog.csdn.net/king_kgh/article/details/74855217

版权声明:
1、JavaClub(https://www.javaclub.cn)以学习交流为目的,由作者投稿、网友推荐和小编整理收藏优秀的IT技术及相关内容,包括但不限于文字、图片、音频、视频、软件、程序等,其均来自互联网,本站不享有版权,版权归原作者所有。

2、本站提供的内容仅用于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯相关权利人及本网站的合法权利。
3、本网站内容原作者如不愿意在本网站刊登内容,请及时通知本站(javaclubcn@163.com),我们将第一时间核实后及时予以删除。


本文链接:https://www.javaclub.cn/database/42354.html

标签: MySQL
分享给朋友:

“mysql的查询缓存” 的相关文章

mysql之基础查询

mysql之基础查询

文章目录 DQL语言的学习 进阶1:基础查询 1.查询表中的单个字段 2.查询表中的多个字段 3.查询表中的所有字段 4.查询常量值...

MySQL 查询指定时间范围内的数据

  说明 mysql 比较时间范围可以直接用 >=、<= 等比较运算符,也可以用 between and(两边都包含,都是闭区间);比较运算符更常用,因为 between and 能做的比较运算符也能做, bet...

mysql的查询句

1、查询特定列:select 列名 from 表名;(必须先进入数据库)或者 select 列名 from 数据库.表名; 2、查询多个列:select 列1,列2,。。。 from 表名; 3、除去重复列查询:select distinct 列名 fr...

MySQL查询某个字段不重复的所有记录

MySQL查询某个字段不重复的所有记录

select a.id,a.ip,a.creationTime from myTable a right join ( select max(id) id from myTable group by ip) b on b.id = a.id where a.id is not n...

mysql查询给某个字段赋值

select case field when ‘’ then ‘指定一个值’ when '未知’then ‘指定一个值’ else field end from table 这种方式遇到null时就不太好使了 当遇到值为null 的情况时这样用 s...

Mysql查询某字段值重复的数据

查询user表中,user_name字段值重复的数据及重复次数 select user_name,count(*) as count from user group by user_name having count>1;   作者:sot...

如何查看MySQL的版本?

查看MySQL的版本,主要有以下几个方法: 1. 没有连接到MySQL服务器,就想查看MySQL的版本。打开cmd,切换至mysql的bin目录,运行下面的命令即可:...

mysql 查询列拼接字段

mysql 拼接字符函数 concat 转自:https://blog.csdn.net/q718330882/article/details/37690677 mysql 的concat函数可以实现数据库中字段的自由拼接 并且保存成临时字段 mysql>...

MySQL查询表中重复字段和重复的次数

查询user表中,user_name字段值重复的数据及重复次数 select user_name,count(*) as count from user group by user_name having count>1;...

mysql 查询某字段最小的记录

根据我所遇到的应用情况,总结了以下3中简单的语句 1. select *,(select field from table t2 order by field) s from table t1  2. select t1.* from table...

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。