首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >mysql有关于sql计划的缓存吗?

mysql有关于sql计划的缓存吗?
EN

Stack Overflow用户
提问于 2010-09-19 15:24:25
回答 3查看 2.9K关注 0票数 3

如果同一个sql在不同的会话中多次运行,mysql会多次解析同一个sql吗?在oracle/sql server中,sql的计划被缓存并可以重用。既然有人说解析和创建sql计划的成本很高,那么如果mysql不缓存它们,那么解析它很多次会有问题吗?这可能会花费很多成本。

EN

回答 3

Stack Overflow用户

发布于 2010-09-19 15:26:08

对于执行计划缓存:我不相信MySQL目前提供了这个特性。

MySQL确实有一个查询缓存:http://dev.mysql.com/doc/refman/5.1/en/query-cache.html

查询缓存存储SELECT语句的文本以及发送到客户端的相应结果。如果稍后收到相同的语句,服务器将从查询缓存中检索结果,而不是再次分析和执行该语句。查询缓存在会话之间共享,因此可以发送一个客户端生成的结果集,以响应另一个客户端发出的相同查询。

我不确定这篇文章(2006)有多新,但它详细讨论了这些问题:http://www.mysqlperformanceblog.com/2006/07/27/mysql-query-cache/

据我所知,从那时起,在这方面没有太大的变化。

票数 1
EN

Stack Overflow用户

发布于 2012-06-07 22:26:38

这是一个现有的MySQL Feature Request

然而,上一条评论(2009年)大意是,它不清楚它是否会提供任何显着的性能改进,并可能导致死锁条件。

票数 1
EN

Stack Overflow用户

发布于 2010-09-19 22:05:06

如果您担心这一点,那么您可能需要考虑使用prepared statements

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3744871

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档