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
- docker如何搭建mysql(docker容器访问宿主机的MySQL操作)
- 如何用wampserver打开自己写的php(WampServer下安装多个版本的PHP、mysql、apache图文教程)
- mysql 高效分页(MySQL 分页查询的优化技巧)
- mysql建表时指定聚簇索引(一看就懂的MySQL的聚簇索引及聚簇索引是如何长高的)
- mysqllinux解压版安装教程学习(解决Linux安装mysql 在/etc下没有my.cnf的问题)
- mysql server安装图解教程(mysql容器之间的replication配置实例详解)
- mysql与oracle如何直接连接(Oracle更换为MySQL遇到的问题及解决)
- mysql开启审计日志会导致性能下降(MySQL 一则慢日志监控误报的问题分析与解决)
- mysql binlog模式实际使用(实例验证MySQL|update字段为相同的值是否会记录binlog)
- 用mysql编写test数据库(MySQL制作具有千万条测试数据的测试库的方法)
- 5.6以上版本mysql数据复制(MySQL5.7并行复制原理及实现)
- 如何找到mysqlroot密码(WDCP管理面板忘记MYSQL ROOT密码及重置后台登录密码的方法汇总)
- centos如何安装mysql8.0版本(Centos7下安装MySQL8.0.23的步骤小白入门级别)
- mysql索引为什么是b+树(mysql 使用B+树索引有哪些优势)
- mysql insert into 怎么用(MySQL中INSERT的一般用法)
- redhat6.5安装mysql(Redhat7.3安装MySQL8.0.22的详细教程二进制安装)
- 历史惊人的相似,美国80万加仑牛奶倒入下水道,意味着什么(历史惊人的相似)
- 美国数十万加仑牛奶倒进下水道,世界会重演1929年的大萧条吗(美国数十万加仑牛奶倒进下水道)
- 美国数十万加仑牛奶倒入下水道,贫民区食不果腹,历史再次重演(美国数十万加仑牛奶倒入下水道)
- 美国倒掉数十万加仑牛奶 上热搜第一,这一幕似曾相识(美国倒掉数十万加仑牛奶)
- 深度 倒牛奶 这一幕为何又在美国上演(深度倒牛奶)
- 美国数十万加仑牛奶倒下水道怎么回事 原因曝光令人心痛(美国数十万加仑牛奶倒下水道怎么回事)
热门推荐
- ui小程序布局(AmazeUI 输入框组的示例代码)
- line-height 百分比与数值的区别
- word-break、word-wrap、white-space的用法
- 腾讯云如何添加安全通信端口(腾讯云服务器如何添加安全通信端口?)
- nginx 配置解析(Nginx的rewrite模块详解)
- html5页面传值表(html5的pushstate以及监听浏览器返回事件的实现)
- rabbitmq客户端内存占用(mysql-canal-rabbitmq 安装部署超详细教程)
- 云服务器怎么创建(怎样操作云服务器)
- 云服务器有必要买吗(云服务器好用吗?云服务器值得买吗?)
- 两个阿里云账号服务器内网通信(阿里云服务器怎么与租用香港服务器组内网?)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9