我正在使用 APC 缓存进行昂贵的查询,该查询检索具有相关文件、付款、事件等的作业。我想知道在 Doctrine 1.* 中是否有可用的缓存失效解决方案。
我想出了以下可行的解决方案,它确实有效,我只是不想发明一个轮子。
如果有更好/其他现有的解决方案,请建议我。
记录侦听器尝试清除具有给定 idpostSave
事件的缓存:
class My_Doctrine_Record_Listener_ClearCache extends Doctrine_Record_Listener
{
/**
* Clear cache by table tags
*
* @param Doctrine_Event $event
* @return null
*/
public function postSave(Doctrine_Event $event)
{
$cache = new Doctrine_Cache_Apc();
/* @var $model Doctrine_Record */
$model = $event->getInvoker();
$name = get_class($model);
/* @var $table Doctrine_Table */
$table = $model->getTable($name);
if (method_exists($table, 'getCacheTags')) {
foreach ($table->getCacheTags() as $tag) {
$id = preg_replace('/%([\w]+)%/e', '$model->{\\1}', $tag);
$cache->delete($id);
}
}
}
}
这就是我在表格中的内容:
class FileTable extends Doctrine_Table
{
/* ... */
public function getCacheTags()
{
return array(
'job_view_%job_id%'
);
}
/* ... */
}
class JobTable extends Doctrine_Table
{
/* ... */
public function getCacheTags()
{
return array(
'job_view_%id%'
);
}
/* ... */
}