我有一个MySQL查询从数据库中选择扫描细节。这些细节放在报告中。它被要求在一页上以两列(几乎两张表)显示报告,以保留它所需的空间。MySql和PHP - 在while循环中取下一行
什么我目前做的是显示表头:
$report .= ">
<table cellspacing='0' class='at_report'>
<thead>
<tr><th colspan='8'>Area ".$row['area_name']."</th></tr>
</thead>
<tr>
<td class='simple_header' style='width:7%;'><div class='nosplit'>No.</div></td>
<td class='simple_header' style='width:8%;'><div class='nosplit'>Barcode</div></td>
<td class='simple_header' style='width:40%;'><div class='nosplit'>Product</div></td>
<td class='simple_header' style='width:5%;'><div class='nosplit'>Qty</div></td>
<td class='simple_header' style='width:7%;'><div class='nosplit'>Cost Value</div></td>
<td class='simple_header' style='width:16%;'><div class='nosplit'>Created By</div></td>
<td class='simple_header' style='width:10%;'><div class='nosplit'>Time</div></td>
<td class='simple_header' style='width:7%;'><div class='nosplit'>No.</div></td>
<td class='simple_header' style='width:8%;'><div class='nosplit'>Barcode</div></td>
<td class='simple_header' style='width:40%;'><div class='nosplit'>Product</div></td>
<td class='simple_header' style='width:5%;'><div class='nosplit'>Qty</div></td>
<td class='simple_header' style='width:7%;'><div class='nosplit'>Cost Value</div></td>
<td class='simple_header' style='width:16%;'><div class='nosplit'>Created By</div></td>
<td class='simple_header' style='width:10%;'><div class='nosplit'>Time</div></td>
</tr>
";
然后我从数据库读取的结果:
while ($srow = $scan_res->fetch(PDO::FETCH_ASSOC))
然后,我在表中显示的结果:
$report .= "<tr ".$row_style.">
<td><div class='nosplit'>".$n."</div></td>
<td><div class='nosplit'>".$srow['barcode']."</div></td>
<td><div class='nosplit'>".$product_nd_short."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$rounded_qty."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$cur_symbol.$cn.$mcost_estimated."</div></td>
<td style='text-align:center;'><div class='nosplit'>".((strlen($srow['stocktake_staff_name'])>16)? substr($srow['stocktake_staff_name'], 0, 16)."..." : $srow['stocktake_staff_name'])."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$dt->format('H:i:s')."</div></td></tr>";
我的问题是,我如何去while循环中的下一组结果,以便我可以在表中添加结果集的另一列吗?我试过这个:
$report .= "<tr ".$row_style.">
<td><div class='nosplit'>".$n."</div></td>
<td><div class='nosplit'>".$srow['barcode']."</div></td>
<td><div class='nosplit'>".$product_nd_short."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$rounded_qty."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$cur_symbol.$cn.$mcost_estimated."</div></td>
<td style='text-align:center;'><div class='nosplit'>".((strlen($srow['stocktake_staff_name'])>16)? substr($srow['stocktake_staff_name'], 0, 16)."..." : $srow['stocktake_staff_name'])."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$dt->format('H:i:s')."</div></td>";
$row_counter++;
$n++;
$report .= "
<td><div class='nosplit'>".$n."</div> </td>
<td><div class='nosplit'>".$srow['barcode']."</div></td>
<td><div class='nosplit'>".$product_nd_short."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$rounded_qty."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$cur_symbol.$cn.$mcost_estimated."</div></td>
<td style='text-align:center;'><div class='nosplit'>".((strlen($srow['stocktake_staff_name'])>16)? substr($srow['stocktake_staff_name'], 0, 16)."..." : $srow['stocktake_staff_name'])."</div></td>
<td style='text-align:center;'><div class='nosplit'>".$dt->format('H:i:s')."</div></td>
</tr>";
但它所做的只是重复第一组的结果。
谢谢!
有关于php.net的文档而且它在那里。 –