mysql未使用索引的查询(如何在mysql进行查询缓存及失败的解决方法)
mysql未使用索引的查询
如何在mysql进行查询缓存及失败的解决方法都知道函数在使用前需要弄清楚参数的属性,这样才能对函数的使用有较好的了解。有些小伙伴学习了查询缓存后,直接进行了下一步的实战操作。这里小编想提醒大家,开始操作之前一定要先设置参数,不然就会出现问题。下面我们来完整的讲一下mysql查询缓存的步骤以及缓存失效的分析。
1.配置参数
(1) have_query_cache表示是否支持查询缓存,YES表示支持
(2) query_cache_type表示缓存类型,OFF表示关闭查询缓存,ON表示开启查询缓存,DEMAND表示用户自定义查询缓存
(3) query_cache_limit表示支持的最大单条查询sql数据量
(4) query_cache_min_res_unit表示查询缓存最小单位
(5) query_cache_size表示查询缓存空间大小
(6) query_cache_wlock_invalidate表示查询缓存是否支持写锁,OFF表示不支持,即读取数据不考虑写锁,ON表示支持,即读取数据会被写锁阻塞
MySQL的查询缓存默认是关闭的,需要手动配置参数query cache type,来开启查询缓存。query cache type该参数的可取值有三个 :
1)OFF或0 :查询缓存功能关闭;
2)ON或1 :查询缓存功能打开,SELECT的结果符合缓存条件即会缓存,否则,不予缓存,显示指定SQL_NO_CACHE,不予缓存
3)DEMAND或2 :查询缓存功能按需进行,显示指定SQL_CACHE的SELECT语句才会缓存;其他均不予缓存。
在/usr/my.cnf配置中,增加以下配置 :
2.开启mysql的查询缓存
|
query_cache_type=1 |
配置完毕之后,重启服务即可生效;
然后就可以在命令行执行SQL语句进行验证,执行一条比较耗时的SQL语句,然后再多执行几次,查看后面几次的执行时间;获取通过查看查询缓存的缓存命中数,来判定是否走查询缓存。
查询缓存使用
(1) 只有字符串相等查询sql才使用相同缓存,即select name from city与SELECT name FROM city不使用同一个缓存。
(2) 在query_cache_type为ON的情况下,默认所有查询都使用缓存,我们可以使用sql_no_cache显示指定某个查询不使用缓存
|
select sql_no_cache name from city; |
(3) 在query_cache_type为DEMAND的情况下,需要使用sql_cache指定某个查询使用缓存
|
select sql_cache name from city; |
3.缓存失效:
在表的结构或数据发生改变时,查询缓存中的数据不再有效。如INSERT、UPDATE、 DELETE、TRUNCATE、ALTER TABLE、DROP TABLE或DROP DATABASE会导致缓存数据失效。所以查询缓存适合有大量相同查询的应用,不适合有大量数据更新的应用。
一旦表数据进行任何一行的修改,基于该表相关cache立即全部失效。
以上就是我们在mysql进行查询缓存需要进行的步骤,在参数的设置方面再次提醒大家。如果缓存失效小伙伴们也不要着急,对应小编的分析找找方法。
原文链接:https://www.py.cn/db/mysql/22059.html
- mysql索引基本知识(MySql索引使用策略分析)
- mysql未使用索引的查询(如何在mysql进行查询缓存及失败的解决方法)
- mysql中的null和空值的区别(解决mysql使用not in 包含null值的问题)
- mysql乐观锁与mvcc(MySQL中的乐观锁,悲观锁和MVCC全面解析)
- 怎么用docker中的mysql连接数据库(解决Docker之mysql容器数据库更改不生效的问题)
- mysql快速备份数据(如何使用Maxwell实时同步mysql数据)
- mysql读写分离怎么做(MySQL读写分离,写完读不到问题如何解决)
- mysqlselect语句汇总(MySQL Select语句是如何执行的)
- mysql中提取日期的函数是什么(MySQL获得当前日期时间函数示例详解)
- SQL SERVER与MySQL数据类型的对应关系
- mysql用户授权的步骤(mysql创建用户并赋予用户权限详细操作教程)
- mysql存储过程limit参数(MySQL存储过程in、out和inout参数示例和总结)
- php+mysql源码部署教程(在WIN主机IIS上支持PHP和MySQL实现方法)
- mysql日志使用(MySQL 日志相关知识总结)
- mysql创建存储过程的代码(MySQL修改存储过程的详细步骤)
- MySQL中使用mysqldump命令备份
- 你喜欢足球吗 足球如何点亮世界的(足球如何点亮世界的)
- 不可分鸽是什么梗(不可分鸽是什么梗)
- 古代的鸽子是爱情的象征,并非和平的使者(古代的鸽子是爱情的象征)
- 一课译词 放鸽子(一课译词放鸽子)
- 终于来了,淘宝更改账户名测试中,快去看看你能不能修改(淘宝更改账户名测试中)
- 淘宝支持账号名修改,网友 终于可以 重新做人 了(淘宝支持账号名修改)
热门推荐
- 查看docker 镜像大小(详解六种减小Docker镜像大小的方法)
- vsftpd详细配置(vsFTPd 服务器初学者指南)
- sql 如何拆分字符串(SQL Server实现将特定字符串拆分并进行插入操作的方法)
- vue导出动态的excel功能(vue中如何下载excel流文件及设置下载文件名)
- C#插入排序
- dedecms创建栏目(dedecms织梦模板栏目列表中添加统计文档数量的标签)
- python爬虫音乐代码(详解python selenium 爬取网易云音乐歌单名)
- python里list操作大全(Python列表List知识点总结)
- uni app开发教程(uniapp+Html5端实现PC端适配)
- php class使用场景(php反射学习之不用new方法实例化类操作示例)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9