我正在测试MySQL中一些查询的速度。数据库正在缓存这些查询,这使得我在测试这些查询有多快时很难得到可靠的结果。
是否有方法禁用查询的缓存?
系统:MySQL 4在Linux主机上,我可以访问PHPMyAdmin。
谢谢
我正在测试MySQL中一些查询的速度。数据库正在缓存这些查询,这使得我在测试这些查询有多快时很难得到可靠的结果。
是否有方法禁用查询的缓存?
系统:MySQL 4在Linux主机上,我可以访问PHPMyAdmin。
谢谢
当前回答
您也可以运行以下命令来重置查询缓存。
RESET QUERY CACHE
其他回答
有一个问题
SELECT SQL_NO_CACHE * FROM TABLE
方法的缺点是,它似乎只会阻止查询的结果被缓存。但是,如果您正在查询一个正在与您想要测试的查询一起使用的数据库,那么其他客户机可能会缓存您的查询,从而影响您的结果。我正在继续研究解决这个问题的方法,如果我找到了一个,我会编辑这篇文章。
我会使用以下方法:
SHOW VARIABLES LIKE 'query_cache_type';
SET SESSION query_cache_type = OFF;
SHOW VARIABLES LIKE 'query_cache_type';
如果你想禁用查询缓存,在你的mysql配置文件中设置query_cache_size为0。如果设置为0,mysql将不使用查询缓存。
任何对当前日期/时间的引用都会禁用该选择的查询缓存:
SELECT *,NOW() FROM TABLE
参见“MySQL查询缓存使用的先决条件和注意事项”@ http://dev.mysql.com/tech-resources/articles/mysql-query-cache.html
您也可以运行以下命令来重置查询缓存。
RESET QUERY CACHE