【发布时间】:2012-02-28 15:56:36
【问题描述】:
我正在处理part4 of Symfony2,在更新控制器和帮助程序类代码时,我收到以下错误消息
Undefined method 'getLatestBlogs'. The method name must start with either
findBy or findOneBy!
在我将一些代码放入控制器之前,我按照教程的教导转移到了我的助手类,这导致了上述错误消息。
<?php
// src/Blogger/BlogBundle/Repository/BlogRepository.php
namespace Blogger\BlogBundle\Repository;
use Doctrine\ORM\EntityRepository;
/**
* BlogRepository
* This class was generated by the Doctrine ORM. Add your own custom
* repository methods below.
*/
class BlogRepository extends EntityRepository
{
public function getLatestBlogs($limit = null)
{
$qb = $this->createQueryBuilder('b')
->select('b')
->addOrderBy('b.created', 'DESC');
if (false === is_null($limit))
$qb->setMaxResults($limit);
return $qb->getQuery()
->getResult();
}
}
这是我的控制器文件索引操作代码:-
// src/Blogger/BlogBundle/Controller/PageController.php
class PageController extends Controller
{
public function indexAction()
{
$em = $this->getDoctrine()
->getEntityManager();
$blogs = $em->getRepository('BloggerBlogBundle:Blog')
->getLatestBlogs();
return $this->render('BloggerBlogBundle:Page:index.html.twig', array(
'blogs' => $blogs
));
}
// ..
}
我从 /Entity/Blog.php 文件中附加了几行。请根据您的回答看看它们是否正确。
<?php
// src/Blogger/BlogBundle/Entity/Blog.php
namespace Blogger\BlogBundle\Entity;
use Doctrine\ORM\Mapping as ORM;
/**
* @ORM\Entity(repositoryClass="Blogger\BlogBundle\Repository\BlogRepository")
* @ORM\Table(name="blog")
* @ORM\HasLifecycleCallbacks()
* @ORM\Entity
*/
class Blog
{
/**
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
* @ORM\HasLifecycleCallbacks()
*/
protected $id;
--
--
}
我哪里做错了?
【问题讨论】:
-
注释和博客类之间也有一个换行符,应该在下面。
-
删除 *.orm.xml 文件对我有用。
-
实际上是因为 Repository 中的 访问修饰符,如果它是私有函数,您应该以
findBy, findOneBy开头,但作为一种良好做法,您 不应该 b> 公开存储库功能。 我使用 Symfony 4.3
标签: symfony