我一直在努力爭取一段時間,我會盡可能簡單地在這裏解釋它。來自多個MySQL表格的單個HTML表格
考慮這個MySQL表:
+----------+-----------+---------+--------+
|status_id |session_id |pilot_id |present |
+----------+-----------+---------+--------+
|1 |61 |901 |1 |
|2 |63 |901 |1 |
|3 |62 |901 |0 |
|4 |62 |902 |1 |
|5 |63 |903 |1 |
+----------+-----------+---------+--------+
兩個session_id
和pilot_id
外鍵使得參照另一個表的主鍵。同一pilot_id
可以與不同的session_id
相關聯,但每個pilot_id
- session_id
組合是唯一的。
我需要一個HTML表(PHP)會顯示這樣的數據:
+----------+---------+---------+---------+
| |61 |62 |63 |
+----------+---------+---------+---------+
|901 |X | |X |
|902 | |X | |
|903 | | |X |
+----------+---------+---------+---------+
因此,行是pilot_id
和列session_id
。當pilot_id
- session_id
組合的值爲1時,應檢查相應的單元格。 (即,當行組合爲零或組合不存在於MySQL表格中時,HTML表格中不應該出現任何內容)
Phew。
任何想法?
謝謝!
我試過erisco提出的答案,但我很困惑。 (評論字段太小,我的解釋,因此這個更新我的問題)。
這是我與工作實際數據:
+----------+-----------+---------+--------+
|status_id |session_id |pilot_id |present |
+----------+-----------+---------+--------+
|7 |65 |33 |1 |
|8 |66 |33 |1 |
|9 |65 |17 |0 |
|10 |66 |16 |1 |
+----------+-----------+---------+--------+
我用$rows = mysqli_fetch_array($result);
。我已經確認查詢正在返回正確的數據。
但是,當我使用ericso提出的答案時,我看起來似乎是任意的數據。下面是生成的HTML表格:
+----------+---------+---------+---------+---------+
| |1 |3 |6 |7 |
+----------+---------+---------+---------+---------+
|1 |X | | | |
|3 | | | | |
|6 | | | | |
|7 | | | | |
+----------+---------+---------+---------+---------+
此外,「X」的位置保持他毫無來由present
值相同。
任何想法爲什麼會發生這種情況?
謝謝!
如果您var_dump'd您的$行與我擁有的$行,您可能會看到不同之處。我會嘗試使用'$ rows = mysqli_fetch_all($ result,MYSQLI_ASSOC);' – erisco 2010-04-14 19:17:10
啊,是的。我看到有什麼不對。當我使用mysqli_fetch_assoc我得到: 陣列(4){ [ 「STATUS_ID」] =>串(1) 「7」 [ 「pilot_id」] =>串(2) 「33」 [ 「SESSION_ID」] => string(2)「65」 [「present」] => string(1)「1」} 這只是第一行...爲什麼? (不管怎樣,我沒有Mysqlnd - 我無法在我的共享服務器上安裝)。這是錯誤: 致命錯誤:調用未定義函數mysqli_fetch_all()。謝謝! – 2010-04-14 20:23:50
我剛剛結束這樣做: $ rows = array(); ($ rawRow = mysqli_fetch_assoc($ result)){ $ rows [] = $ rawRow; } – 2010-04-14 21:25:03