3

存储过程应该缓存在 Mysql 中吗?如果是,它会在缓存中停留多长时间?

就我而言,当我第一次调用一个存储过程时,它会在 1 秒内给我结果,然后在 400 毫秒内给我结果。当我更改传递给存储过程的一些参数并第一次调用时,执行相同的行为。所以,我无法理解发生了什么?有人可以指导我吗?

谢谢。

4

2 回答 2

2

这是任何使用缓存的系统的正常行为:

  • 在第一次执行时,结果被加载到缓存中,因此出现了一个小的开销
  • 以下执行将花费更少,因为它们已经在缓存中但是如果任何输入发生更改(例如在您的情况下:更改存储过程的某些参数),那么已经在缓存中的结果不再可行,因此新结果(使用更改的输入)必须放在缓存中,这就是为什么它需要更长的时间

你可以在这里阅读更多

于 2013-05-10T08:11:58.710 回答
0

在您的过程中使用 Deallocate :

CREATE PROCEDURE GetVenues (TheVenue varchar(22)) 
BEGIN 
SET @s = 'SELECT * FROM Venues WHERE VenueName = ?'; 
SET @v = TheVenue;
PREPARE stmt1 FROM @s; 
EXECUTE stmt1 USING @v; 
DEALLOCATE PREPARE stmt1; 
END;

其他选项:RESET QUERY CACHE;

如果您运行的用户具有重新加载权限。或者,您可以通过以下方式对查询缓存进行碎片整理:

FLUSH QUERY CACHE;

于 2017-08-03T12:37:51.557 回答