mysql 查询缓存相关

/*
查询mysql是否开启查询缓存,以及缓存大小
下面查询结果解释:
    query_cache_type:是否缓存(0或off:关闭。1或on:开启缓存。2或demand:开启有条件缓存,只缓存带sql_cache的select语句,如:select  sql_cache name from wei where id=4 )
    query_cache_size:缓存大小
    query_cache_limit:单个查询能够使用的缓冲区大小,缺省为1M
    have_query_cache:是否开启
    query_cache_min_res_unit:系统分配的最小缓存块大小,默认是4KB,设置值大对大数据查询有好处,但如果你的查询都是小数据 查询,就容易造成内存碎片和浪费
    query_cache_wlock_invalidate:当有其他客户端正在对MyISAM表进行写操作时,如果查询在query cache中,是否返回cache结果还是等写操作完成再读表获取结果
*/

show variables like '%query_cache%';

 

/*
  查看现在缓存的情况
  查询结果解释:
        Qcache_free_blocks:缓存中相邻内存块的个数。数目大说明可能有碎片。FLUSH QUERY CACHE会对缓存中的碎片进行整理,从而得到一个空闲块。
        Qcache_free_memory:缓存中的空闲内存。
        Qcache_hits:每次查询在缓存中命中时就增大
        Qcache_inserts:每次插入一个查询时就增大。命中次数除以插入次数就是不中比率。
        Qcache_lowmem_prunes:缓存出现内存不足并且必须要进行清理以便为更多查询提供空间的次数。这个数字最好长时间来看;如果这个 数字在不断增长,就表示可能碎片非常严重,或者内存很少。(上面的         free_blocks和free_memory可以告诉您属于哪种情况)
        Qcache_not_cached:不适合进行缓存的查询的数量,通常是由于这些查询不是 SELECT 语句或者用了now()之类的函数。
        Qcache_queries_in_cache:当前缓存的查询(和响应)的数量。
        Qcache_total_blocks:缓存中块的数量。

*/

show status like 'qcache%';

 

/*
临时关闭缓存
*/

set global query_cache_size=0

set global query_cache_type=0

/*
永久的修改配置文件my.ini ,添加下面的配置即可。

Windows下MySQL的配置文件是my.ini,一般会在安装目录的根目录。

Linux下MySQL的配置文件是my.cnf,一般会放在/etc/my.cnf,/etc/mysql/my.cnf。如果找不到,可以用find命令查找

注意改完要重启数据库
*/

query_cache_type=0

query_cache_size=0


/*
在sql中通过设置关键字,使sql缓存或者不缓存
*/

Select sql_no_cache count(*) from users; 不缓存

Select sql_cache count(*) from users; 缓存(也可以不加,默认缓存已经开启了)

 

 

参考链接:

https://www.cnblogs.com/eyesfree/p/7232559.html
https://www.jb51.net/article/75955.htm
https://www.cnblogs.com/wanglin2016/p/7670243.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值