当前位置:  开发笔记 > 编程语言 > 正文

如何使用Doctrine Criteria过滤掉数组属性?

如何解决《如何使用DoctrineCriteria过滤掉数组属性?》经验,为你挑选了0个好方法。

我在Symfony实体类中添加了一个虚拟属性.此属性应基于另一个表数据计算 - 特别是在Doctrine数组类型的列上.

class RelatedEntity
{

    /* ... */

    /**
     * @ORM\Column(type="array")
     */
    protected $type;

关键是我想使用Doctrine Criteria,因为它应该在SQL级别上进行优化.所以我这样做了:

public function getCreated()
{
    $criteria = Criteria::create()->where(Criteria::expr()->contains('type', 'create'));
    $relatedEntity = $this->getRelatedEntities()->matching($criteria);

    if (!$relatedEntity) {
        return null;
    }

    return $relatedEntity->getTimestamp();
}

但我得到一个空的结果集.即使Doctrine正在构建一个正确的SQL语句,当我手动将其键入PostgreSQL数据库时,它也能正常工作.

...WHERE type LIKE '%create%'

这种方法有什么问题,如何解决?现在我使用ArrayCollection过滤器方法完成了这个技巧,但它加载了我不需要的所有相关实体.

谢谢你的任何想法.

编辑:这不是上述问题的重复,因为我不能在实体内使用EntityManagerEntityRepository.我需要使用Criteria,因此问题中提出的解决方案对我不起作用.

推荐阅读
php
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有