How to return an array not an object with doctrine findOneBy method in symfony2?(如何在 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 方法返回数组而不是对象?
基础教程推荐
- 通过 PHP SoapClient 请求发送原始 XML 2021-01-01
- WooCommerce 中选定产品类别的自定义产品价格后缀 2021-01-01
- 在 Woocommerce 中根据运输方式和付款方式添加费用 2021-01-01
- 如何在 PHP 中的请求之间持久化对象 2022-01-01
- 超薄框架REST服务两次获得输出 2022-01-01
- mysqli_insert_id 是否有可能在高流量应用程序中返回 2021-01-01
- Libpuzzle 索引数百万张图片? 2022-01-01
- 在 PHP 中强制下载文件 - 在 Joomla 框架内 2022-01-01
- 在多维数组中查找最大值 2021-01-01
- XAMPP 服务器不加载 CSS 文件 2022-01-01