我正在测试MySQL中一些查询的速度。数据库正在缓存这些查询,这使得我在测试这些查询有多快时很难得到可靠的结果。

是否有方法禁用查询的缓存?

系统:MySQL 4在Linux主机上,我可以访问PHPMyAdmin。

谢谢


当前回答

在查询中使用用户定义的变量会使查询结果不可缓存。我发现它是一个比使用SQL_NO_CACHE更好的指示器。但是你应该把变量放在一个变量设置不会严重影响性能的地方:

SELECT t.*
FROM thetable t, (SELECT @a:=NULL) as init;

其他回答

还有一个配置选项:query_cache_size=0

要在服务器启动时禁用查询缓存,请将系统变量query_cache_size设置为0。通过禁用查询缓存代码,不会产生明显的开销。如果从源代码构建MySQL,则可以通过使用——without-query-cache选项调用configure,将查询缓存功能完全排除在服务器之外。

参见http://dev.mysql.com/doc/refman/5.1/en/query-cache.html

在查询中使用用户定义的变量会使查询结果不可缓存。我发现它是一个比使用SQL_NO_CACHE更好的指示器。但是你应该把变量放在一个变量设置不会严重影响性能的地方:

SELECT t.*
FROM thetable t, (SELECT @a:=NULL) as init;

尝试在查询中使用SQL_NO_CACHE (MySQL 5.7)选项。 (MySQL 5.6用户点击这里)

eg.

SELECT SQL_NO_CACHE * FROM TABLE

这将停止MySQL缓存结果,但是请注意,其他操作系统和磁盘缓存也可能影响性能。这些都很难绕过。

另一个只影响当前连接的选项:

SET SESSION query_cache_type=0;

您也可以运行以下命令来重置查询缓存。

RESET QUERY CACHE