我正在使用Doctrine开发Symfony2项目。我想通过向查询添加缓存来优化API性能。
我看过几个选项,例如:
不确定我应该去哪一个,但对我而言,似乎在Doctrine级别缓存数据是最合适的。
说我希望有人帮助我或指导我如何设置Doctrine缓存并解释它是如何工作的。
我有这个问题:
class QueryFactory
protected $connect;
public function __construct(Connection $connection)
{
$this->connect = $connection;
}
private function myQuery()
{
return $this->connect->createQueryBuilder()
->select('user_id')
->from('users', 'u')
->where('u.user_id = 2');
}
}
如何为此查询添加缓存?是否有任何Doctrine库我需要注入use
所需的任何东西?
答案 0 :(得分:20)
在doctrine
中缓存查询或结果,您可以执行以下操作:
private function myQuery()
{
return $this->connect->createQueryBuilder()
->select('user_id')
->from('users', 'u')
->where('u.user_id = 2')
->getQuery()
->useQueryCache(true) // here
->useResultCache(true); // and here
}
检查doc以获取有关这些方法的更多信息。这将使your
缓存驱动程序正常工作 - 与您使用的驱动程序无关。
要配置Symfony
以使用特定查询驱动程序,您需要在config.yml
中调整设置 - 检查this以查看完整的选项列表。缓存中最重要的是(这是apc
配置示例):
entity_managers:
some_em:
query_cache_driver: apc
metadata_cache_driver: apc
result_cache_driver: apc