我试图在单次迭代中获得两个数据行:
$query = mysql_query("SELECT * FROM tbl_website_index")or die(mysql_error());
while($row = mysql_fetch_assoc($query)){
//returns single row`
}
在 html 表中
单行2条数据线
<tr>
<td>data 1</td>
<td>data 2</td>
</tr>
我不确定你是否想要这个,但试试:
<tr>
<?php
$query = mysql_query("SELECT * FROM tbl_website_index")or die(mysql_error());
while($row = mysql_fetch_assoc($query)){
?>
<td><?php echo $row['col'] ?></td>
<?php
}
?>
首先 - 请不要使用 mysql_query 而是使用 PDO。其次 - 你永远不会这样做。使用引用 (next()) 可以通过多种方式实现这一目标。但这非常糟糕。因此,我提出这样的建议:
$query = $this->db->prepare("select * from tbl_website_index");
$query->execute();
$data = array();
while ($row = $query->fetch(PDO::FETCH_OBJ))
{
$data[] = $row->fieldName;
}
$data = "<li>" . implode("</li><li>", $data) . "</li>";
print "<ul>" . $data . "</ul>";
那将实现您正在尝试做的事情。不过我还没有测试过。
首先将所有数据放入一个数组中。然后组成该数组多维数组。因此,您可以在每个键中按两行类似的方式。
while($row = mysql_fetch_assoc($query)){
$data[] = $row;
}
$last_data = array();
$key = 0;
for($i=0;$i<sizeof($data);$i++) {
if($i%2 == 0)
{
$key++;
}
$last_data[$key][] = $data[$i];
}
然后你可以遍历 html 表。
<?php foreach ( $last_data as $key => $row) { ?>
<tr>
<?php foreach ( $row as $k => $row1) { ?>
<td> <?php echo $row1['field'] ?></td>
<?php } ?>
</tr>
<?php } ?>
(建议使用 mysqli_* 而不是 mysql_* 来保留您的代码使用已弃用的扩展。)