Symfony and Doctrine - 显示数据库中的数据


Symfony and Doctrine - displaying data from database

我正在尝试显示数据库中的数据。

这是我的路由:

pages:
    pattern: /pages/{id}
    defaults:
       _controller: DprocMainBundle:Index:show

这是该路由的方法:

public function showAction($id)
    {
        $page = $this->getDoctrine()
           ->getRepository('DprocMainBundle:Pages')
           ->find($id);
        if (!$page) {
           throw $this->createNotFoundException('No product found for id '.$id);
        }
        return $this->render('DprocMainBundle:Dproc:single.html.twig',array('pages' => $page));
    }

print_r($page) 显示:

Dproc'MainBundle'Entity'Pages Object
(
    [Id:protected] => 1
    [page_title:protected] => A Foo Bar
    [page_content:protected] => Test content for page
    [page_category:protected] => 3dsmax
)

在 single.html.twig 中,我试图显示该信息:

{% for page in pages %}
    {{ page.page_title }}
{% endfor %}

它什么也没显示,我做错了什么?

方法find()将只返回单个结果,而不是数组。如果你做了findBy(array('id'=>$id))那么你会得到一个带有一个结果的数组。或者,您可以不在模板中循环访问,因为当您只有一个结果时,就没有必要了。只需将变量名称更改为 page 并使用{{ page.page_title }}

你使用了两个不同的实体..一个在getRepository('DprocMainBundle:Pages')中,另一个在render('DprocMainBundle: Dproc :single.html.twig',array('pages' => $page))。你应该把同样的实体放在那里,即DprocMainBundle:Pages.我希望你成功。

尝试一下没有 for 循环。因为您有来自数据库的发布数据,所以您可以尝试以下操作:

{{ pages.page_title }}