你的
while
循环正在关闭
<tr>
在每次迭代中都在上面加上标记,但是你不可能用完全不可读的代码看到它。
我冒昧地为你整理了一下:
您还分配了一些完全无用的变量。我也修过了。
<?php
$host="localhost"; // Host name
$username="abc"; // Mysql username
$password="password"; // Mysql password
$db_name="abc"; // Database name
$tbl_name="portfolio"; // Table name
$conn=mysql_connect("$host", "$username", "$password")or die("cannot connect");
mysql_select_db("$db_name")or die("cannot select DB");
$sql="select * from ".$tbl_name.";";
$result = mysql_query($sql) or die(mysql_error());
?>
<table class="tickerContain">
<tr>
<td>ID</td>
<td>TICKER</td>
<td>PRICE</td>
<td>CommIn</td>
<td>CommOut</td>
<td>DateIn</td>
<td>LPrice</td>
<td>%CHG</td>
<td>PNL</td>
</tr>
<?php while ($row = mysql_fetch_array($result)) : ?>
<tr>
<td id="<?php echo $row["ticker"]; ?>id">
<?php echo $row["id"]; ?>
</td>
<td id="<?php echo $row["ticker"]; ?>ticker">
<?php echo $row["ticker"]; ?>
</td>
<td id="<?php echo $row["ticker"]; ?>price">
<?php echo $row["price"]; ?>
</td>
<td id="<?php echo $row["ticker"]; ?>commissionIn">
<?php echo $row["commissionIn"]; ?>
</td>
<td id="<?php echo $row["ticker"]; ?>commissionOut">
<?php echo $row["commissionOut"]; ?>
</td>
<td id="<?php echo $row["ticker"]; ?>dateIn">
<?php echo $row["dateIn"]; ?>
</td>
<td>
<textarea class="realTime" id="<?php echo $row["ticker"]; ?>LPrice">
<?php echo $row["ticker"]; ?>
</textarea>
</td>
<td>
<textarea class="realTime" id="<?php echo $row["ticker"]; ?>pctChange">
<?php echo $row["ticker"]; ?>
</textarea>
</td>
<td>
<textarea class="realTime" id="<?php echo $row["ticker"]; ?>pnl">
<?php echo $row["ticker"]; ?>
</textarea>
</td>
</tr>
<?php endwhile; ?>
</table>
另外,我建议将数据库代码移动到另一个文件,并将其包含到脚本中。
看看MVC架构(
http://en.wikipedia.org/wiki/Model
_“查看_”控制器),它将显著帮助您保持代码的整洁。