你需要加入表:
SELECT A.Agent_Name, C.Country_Name, J.Job_Type
FROM Line_Items LI, Agents A, Country C, Job J
WHERE LI.Agent_ID = 1 AND LI.Agent_ID = A.Agent_ID AND
LI.Country_ID = C.Country_ID AND LI.Job_ID = J.Job_ID
此外,可以考虑使用视图,就像这样:
CREATE VIEW Line_Items_Detail
AS
SELECT LI.Agent_ID, A.Agent_Name, C.Country_Name, J.Job_Type
FROM Line_Items LI, Agents A, Country C, Job J
WHERE LI.Agent_ID = 1 AND LI.Agent_ID = A.Agent_ID AND
LI.Country_ID = C.Country_ID AND LI.Job_ID = J.Job_ID
然后,使用视图,您的查询简单如下:
SELECT Agent_Name, Country_Name, Job_Type
FROM Line_Items_Detail
WHERE Agent_ID = 1
使用任何这些查询,您可以使用您编写的PHP代码输出结果。
希望它有帮助。
编辑
使用的第一个查询,你的PHP会是这样(简化):
$query = "SELECT A.Agent_Name, C.Country_Name, J.Job_Type FROM Line_Items LI, Agents A, Country C, Job J WHERE LI.Agent_ID = 1 AND LI.Agent_ID = A.Agent_ID AND LI.Country_ID = C.Country_ID AND LI.Job_ID = J.Job_ID";
$result = mysql_query($query);
while($row = mysql_fetch_query($result)) {
echo "Agent:" . $row['Agent_Name']."<br>";
echo "Country:" . $row['Country_Name']."<br>";
echo "Job:" . $row['Job_Type']."<br>";
}
当然,您需要更改LI.Agent_ID
如果你需要一个不同的ID。您可以为其使用占位符并替换为正确的ID,或将正确的ID连接到查询。
对不起,不知道如何可以对这些结果在PHP :( – Felix 2009-08-22 18:28:50
我已经编辑我原来的职位,以应付这一点。 – 2009-08-22 18:36:42
谢谢谢谢谢谢! 这个工作,我爱StackOverflow的输出! – Felix 2009-08-22 18:47:02