我正在创建一个HTML表,其中包含来自MySQL数据库的数据行和一些计算值,如下所示:
<?php
$connection = mysql_connect('localhost','root','') or die('Connection failed!');
mysql_select_db('MyDB', $connection);
$result = mysql_query('SELECT * FROM DB_TABLE');
?>
<table>
<tr>
<th scope="col">Heading 1</th>
<th scope="col">Tariefplan</th>
<th scope="col">Abonnementskost</th>
<th scope="col">Maandelijkse korting</th>
<th scope="col">Contractduur</th>
<th scope="col">Inbegrepen in bundel</th>
<th scope="col">Tarieven buiten bundel</th>
<th scope="col"></th>
<th scope="col">Bereken minuten</th>
<th scope="col">Bereken SMS'en</th>
<th scope="col">Bereken MB's</th>
<th scope="col"></th>
<th scope="col">Totale prijs normaal</th>
<th scope="col">Totale prijs promotie</th>
<th scope="col">Totale prijs contract</th>
</tr>
<?php
while ($data = mysql_fetch_assoc($result)) {
?>
<tr>
<th scope="row"><?php echo $data['provider']; ?></th>
<td><?php echo $data['planname']; ?></td>
<td>€ <?php echo $data['price_normal']; ?> per maand<br />
<sub>gedurende <?php echo ($data['contract_duration']-$data['promo_duration']); ?> maanden</sub></td>
<td>- € <?php echo $data['promo_discount']; ?> per maand<br />
<sub>gedurende <?php echo $data['promo_duration']; ?> maanden</sub><br />
<sub>promotie geldig tot <?php echo $data['promo_valid']; ?></sub></td>
<td><?php echo $data['contract_duration']; ?> maanden</td>
<td>
<ul>
<li><?php echo $data['included_min']; ?> minuten</li>
<li><?php echo $data['included_sms']; ?> SMS'en</li>
<li><?php echo $data['included_mb']; ?> MB's</li>
<li>€ <?php echo $data['included_value']; ?> belwaarde</li>
</ul>
</td>
<td>
<ul>
<li>€ <?php echo $data['price_min']; ?> per minuut</li>
<li>€ <?php echo $data['price_sms']; ?> per SMS</li>
<li>€ <?php echo $data['price_mb']; ?> per MB</li>
</ul>
</td>
<td></td>
<td>
<?php
if ($_POST['used_min'] <= $data['included_min']) {
$calc_min = 0;
}
else {
$calc_min = ($_POST['used_min'] - $data['included_min']) * $data['price_min'];
}
echo '€ ' . $calc_min;
?>
</td>
<td>
<?php
if ($_POST['used_sms'] <= $data['included_sms']) {
$calc_sms = 0;
}
else {
$calc_sms = ($_POST['used_sms'] - $data['included_sms']) * $data['price_sms'];
}
echo '€ ' . $calc_sms;
?>
</td>
<td>
<?php
if ($_POST['used_mb'] <= $data['included_mb']) {
$calc_mb = 0;
}
else {
$calc_mb = ($_POST['used_mb'] - $data['included_mb']) * $data['price_mb'];
}
echo '€ ' . $calc_mb;
?>
</td>
<td></td>
<td>
<?php
$used_total = ($calc_min + $calc_sms + $calc_mb);
if ($data['included_value'] > $used_total) {
$total_price_normal = $data['price_normal'];
}
else {
$total_price_normal = ($data['price_normal'] + $used_total);
}
echo '€ ' . $total_price_normal . ' per maand';
?>
</td>
<td>
<?php
$total_price_discount = ($total_price_normal - $data['promo_discount']);
echo '€ ' . $total_price_discount . ' per maand';
?>
</td>
<td>
<?php
$total_price_contract = ($total_price_normal * ($data['contract_duration']-$data['promo_duration'])) + ($total_price_discount * $data['promo_duration']);
echo '€ ' . $total_price_contract . ' per maand ' . $data['contract_duration'] . ' na maanden';
?>
</td>
</tr>
<?php } ?>
</table>
表格中的最后一列是一个变量值,用于计算总金额。这未列在数据库中。 我想将此表输出到一个浏览器页面,让我们对最后一列进行排序。
使用PHP sort()
或asort()
函数无效。
有人有解决方案吗?
答案 0 :(得分:3)
在SQL查询中进行计算,让数据库处理排序
答案 1 :(得分:2)
您首先计算值,然后创建表格。或者使用一些JavaScript。因此,您必须通过$ result并将计算值放入数组中,之后您可以使用值对表进行排序和打印,并按最后一个值排序。
答案 2 :(得分:2)
我认为如果您首先遍历结果,进行计算并将所有内容放入数组中会更好。然后,您可以使用任何PHP函数对数组进行排序并输出。使用这种方法最好的方法是,您将获得更清晰的表输出,因为所有计算和输出都远离HTML输出;)
另一个想法是,你像上面那样做,然后在Javascript / jQuery中使用tablesorter来对你的行进行排序。
答案 3 :(得分:2)
这是可能的,但使用PHP执行此操作可能会很棘手。为了快速修复,您可以尝试这个jquery解决方案,它可以满足您的需求,让您快速启动并运行。
答案 4 :(得分:1)
使用PHP sort()或asort()函数不能正常工作。
如果你的意思与1, 10, 12, 2
类似,你可以使用natsort();。