0

我正在尝试从数据库加载数据并将其显示在如下表中:

http://img196.imageshack.us/img196/1857/cijene.jpg

在数据库中,我有两个表:

cities (id, name)
prices (id, city1_id, city2_id, price)

例如,4 个城市的打印表如下所示:

<table>
 <tr>
  <td>city1</td>
  <td> </td>
  <td> </td>
  <td> </td>
 </tr>

 <tr>
  <td> price_city1-city2</td>
  <td>city2</td>
  <td> </td>
  <td> </td>
 </tr>

 <tr>
  <td> price_city1-city3</td>
  <td> price_city2-city3</td>
  <td>city3</td>
  <td> </td>
 </tr>

 <tr>
  <td> price_city1-city4</td>
  <td> price_city2-city4</td>
  <td> price_city3-city4</td>
  <td>city4</td>
 </tr>
</table>

有人知道回显这种表的 PHP 语句是什么吗?

4

3 回答 3

1

我使用了一种非常简单的方法将查询结果转换为 HTML 表。我测试 $query_result 是否为真,并将结果作为关联数组获取...

$query_result = mysqli_query($db, $query);

if ($query_result) {

    while ($columns = mysqli_fetch_assoc($query_result)) {

        echo "<tr>\n";

        foreach ($columns as $name => $column) {
            echo "<td>";
            printf("%s",$columns[$name]);
            echo "</td>\n";
        }

        echo "</tr>\n";
    }
}

编辑:现在我已经能够查看您的表格,我可以看到我还没有真正回答您的问题。查询显然非常重要。问题是否变成了“我如何创建一个返回结果的查询,这些结果可以通过我的简单方法变成一个表?”

我希望其他人有一些想法。

于 2009-09-09T23:17:56.840 回答
1

这在某种程度上处于实用性的边缘,但我更多地将这个问题视为“正确行事”的练习。

我会对每个表做一个简单的选择并插入到一个数组中:

$query1 = "SELECT * FROM 城市";
$query2 = "SELECT * FROM 价格";

$results1 = mysql_query($query1);
$results2 = mysql_query($query2);

而( $rows = mysql_fetch_array( $results1 ) ) $cities[] = $row['name'];
而( $rows = mysql_fetch_array( $results2 ) ) $prices[] = array(
                                                               $row['city1_id'],
                                                               $row['city2_id'],
                                                               $行['名称']
                                                            );

然后我将使用它来动态创建两个 javascript 列表:

$java_array1 = "var Cities = 新数组;\n";
foreach( $cities as $key=>$city ) $java_array1 .= "Cities[$key] = \"$city\";\n";
$java_array2 = "var 价格 = 新数组;\n";
foreach( $cities as $key=>$price ) $java_array2 .= "价格[$key] = new Array(
                                                                     \"{$price[0]}\",
                                                                     \"{$price[1]}\",
                                                                     \"{$price[2]}\",
                                                                  );\n";

接下来,我会为每个单元格输出一个带有精心制作的 id 的表格。我会使用与第一个答案中的代码非常相似的代码,但我会给每个单元格一个唯一的"cell-<row>-<col>".

我要做的最后一件事是编写一些onloadjavascript,这些 javascript 将使用适当的配对填充表格。我的 javascript 很生锈,但它看起来像这样(注意:伪代码如下):

n = 1;
for( var i 在城市中)
{
    // 在对角线上设置城市名称
    document.getElementById('cell-'&i&'-'&i).innerHTML = names[i];
    n = n + 1;
}

for( var j in 价格 )
{
    // 使用价格数组中的城市 ID(参见前面的代码初始化
    // 价格数组)放置价格
    document.getElementById('cell-'&prices[1]&'-'&prices[2]).innerHTML = prices[0];
}

我几乎肯定搞砸了一些 javascript;使用风险自负。

这比上面给出的简单答案要复杂得多,但这是我能想到的唯一方法,以便它“有意义”。基本上,使用这种方法,您可以将所有内容放在应有的位置,而不必担心奇怪的表格和奇怪的选择。

于 2009-09-10T00:30:05.990 回答
1
// This single query gets all required data
// NOTE: this query assumes that your price data is entered
//   such that from_city always alphabetically precedes to_city!
$sql =
    "SELECT a.name AS from_city, b.name AS to_city, price ".
    "FROM prices ".
    "INNER JOIN cities AS a ON a.id=prices.city1_id ".
    "INNER JOIN cities AS b ON b.id=prices.city2_id";


// connect and do query
$conn = mysql_connect($host, $user, $pass);
mysql_select_db($db, $conn);
$q = mysql_query($sql, $conn);


// Stuff all data into an array for manipulation;
//   keep list of all cities mentioned
$price = array();
$cities = array();
while (($res = mysql_fetch_assoc($q)) !== false) {
    $from = $res['from_city'];
    $cities[ $from ] = true;

    $to = $res['to_city'];
    $cities[ $to ] = true;

    $price[$to][$from] = $res['price'];
}

// Invert to get alphabetical list of cities
$cities = array_keys($cities);
sort($cities);
$num = count($cities);


// some utility functions
function table($rows) {
    return '<table>'.join($rows).'</table>';
}
function row($cells) {
    return '<tr>'.join($cells).'</tr>';
}
function cell($text) {
    $text = (string) $text;
    if (strlen($text)==0)
        $text = '&nbsp;';
    return '<td>'.$text.'</td>';
}


// The data is now in the desired order;
// produce output as HTML table
$rows = array();
for ($to = 0; $to < $num; ++$to) {
    $t = $cities[$to];
    $cells = array();

    for ($from = 0; $from < $to; ++$from) {
        $f = $cities[$from];

        if isset($price[$t]) && isset($price[$t][$f])
            $text = $price[$t][$f];
        else
            $text = '';

        $cells[]= cell($text);
    }

    $cells[]= cell($t);    // add destination-label

    for ($from = $to+1; $from < $num; ++$from)   // pad to proper number of cells
        $cells[]= cell('');

    $rows[]= row($cells);
}
$html = table($rows);


// show results!
echo $html;
于 2009-09-10T01:25:19.907 回答