如果同一个sql从不同的会话中运行多次,mysql会多次解析同一个sql吗?在oracle / sql server中,sql的计划被缓存并可以重用。既然它被告知解析和创建sql计划代价很高,如果mysql没有缓存它们,那么解析它会花很多时间来解决这个问题吗?
答案 0 :(得分:1)
对于执行计划缓存:我不相信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 :(得分:1)
这是现有的MySQL Feature Request。
然而,最后的评论(在2009年),根据它不清楚它会提供任何显着的性能改进,并可能导致死锁条件。
答案 2 :(得分:0)
如果您对此感到担心,可能需要考虑使用prepared statements。