微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php – 如何获得doctrine2实体一对多设置为“活动”的实体

让我们假设博客帖子和评论之间存在OnetoMany doctrine2关联.博客帖子可能有很多评论.每个评论都保持不活动状态,因此隐藏在前端,直到主持人手动激活评论.

我现在正在尝试使用某种安全外观来确保只通过在twig模板中的{{blogpost.comments}}变量的循环中访问它们,只为视图提供“活动”注释.

试图在blogpost实体中使用getComments()方法我试图过滤像这样的注释的ArrayCollection

/**
 * @return ArrayCollection
 */
public function getComments()
{
    return $this->comments->filter(function ($condition) {
        return $condition->getActive() === true;
    });
}

不幸的是,即使关系提取模式设置为“EXTRA_LAZY”,Doctrine也会完全加载每个注释.所以这会以我想避免的方式影响应用程序的性能.

有没有办法在全局隐藏不活动的注释,或者我每次访问视图中的blogpost.comments关系时是否必须注意过滤它们?

解决方法:

您应该使用集合的匹配方法.如果未加载您的集合,它将向SQL查询添加过滤器以仅加载您需要的内容.如果您的集合已经加载,它将过滤PHP数组.

use Doctrine\Common\Collections\Criteria;

public function getComments()
{
    return $this->comments->matching(
        Criteria::create()->where(
            Criteria::expr()->eq('active', true)
        )
    );
}

更多信息:http://doctrine-orm.readthedocs.org/projects/doctrine-orm/en/latest/reference/working-with-associations.html#filtering-collections

问候

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐