沃梦达 / 编程问答 / php问题 / 正文

如何在 symfony2 中使用学说 findOneBy 方法返回数组而不是对象?

How to return an array not an object with doctrine findOneBy method in symfony2?(如何在 symfony2 中使用学说 findOneBy 方法返回数组而不是对象?)

本文介绍了如何在 symfony2 中使用学说 findOneBy 方法返回数组而不是对象?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一种情况,我想使用 symfony2 中的学说中的 findOneBy($id) 方法查询数据库.

I have a situation in which I want to query the database with findOneBy($id) method from doctrine in symfony2.

$namePosting = $this->getDoctrine()->getRepository('MyBundle:Users')->findOneById($userPosting);

结果它是一个具有受保护属性的对象.我想直接返回一个数组.如何才能做到这一点 ?

The result it's an object with protected properties. I want to return it directly an array. How can this be done ?

推荐答案

findOneBy(array()) 将始终返回 null 或 object.

findOneBy(array()) will always return null or object.

但您可以使用 findById($userPosting)findBy(array('id' => $userPosting)) 来代替它,它会返回一个数组,例如:

But you can use instead findById($userPosting) or findBy(array('id' => $userPosting)) and it will return an array, e.g.:

$this->getDoctrine()->getRepository('MyBundle:Users')->findById($userPosting))

已编辑

或者你可以在 UserRepository 类中添加一个方法:

    use DoctrineORMEntityRepository;
    use DoctrineORMQuery;

    class UserRepository extends EntityRepository
    { 
        public function getUser($userPosting)
        {
           $qb = $this->createQueryBuilder('u')
             ->select('u')
             ->where('u =:userPosting')->setParameter('userPosting', $userPosting)
             ->getQuery()
             ->getResult(Query::HYDRATE_ARRAY);

           return $qb;
        }   
    }

这篇关于如何在 symfony2 中使用学说 findOneBy 方法返回数组而不是对象?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:如何在 symfony2 中使用学说 findOneBy 方法返回数组而不是对象?