在Twig模板中显示MySQL查询结果

时间:2015-09-22 15:09:19

标签: php mysql twig

我正在实施我的第一个Twig项目。我有一个MySQL数据库。它包括一个表,其中每个记录是一个文档。有标题,数字和描述字段。

没有Twig,查询所有结果并将它们输出到表格非常简单。但是,我在查询Twig时遇到了一些困难。这似乎是一项基本任务,但我没有在Twig文档中找到任何类似的示例或搜索过。

Twig模板看起来很像Django / Jinja模板,我更熟悉。我的模板:

{% block Content %}

<table border='1' width=100%>
    {% for i in queryResult %}
    <tr>
        <td> {{i.Title}} </td>
    </tr>
    {% endfor %}
</table>
{% endblock %}

此视图的PHP如下所示:

$connection=mysql_connect (credentials) or die ('Cannot connect to database:' . mysql_error());
    $mydb=mysql_select_db(database);

$sql = query;

$query = mysql_query($sql);

$result = mysql_fetch_assoc($query);

echo $twig -> render('all_reports.html', array('queryResult'=> $result));

这似乎是正确的。该脚本应执行SQL查询,将结果集作为数组返回,然后将结果发送到模板。模板应迭代数组中的所有项(每行一项)并将其显示在表中。

实际发生的是渲染了三行,全部为空白。我的解释是模板在数组中看到三个项目(每个字段一个),而不是查询结果中每个记录的项目。它们是空白的,因为每个字段都没有标题字段。但是我不知道会解决这个问题。

1 个答案:

答案 0 :(得分:2)

在PHP中试试这个:

while ($row = mysql_fetch_assoc($query)) {
    $results[] = $row;
}
echo $twig -> render('all_reports.html', array('queryResult'=> $results));

问题是你正在调用mysql_fetch_assoc,这将获得第一行(在你的情况下似乎是空白的)。构建数组并将其发送到模板中。