2009-08-22 122 views
0

我在MySQL的至少4代表为我的PHP应用程序(缩短它在这个例子中)如何从多个mySQL表中选择并输出到PHP?

代理 - AGENT_ID - AGENT_NAME

国家 - COUNTRY_ID - COUNTRY_NAME

工作 - Job_ID - Job_Type

Line_Items - Line_ID - AGENT_ID - COUNTRY_ID - JOB_ID

现在,我需要从Line_Items选择在哪里,以及AGENT_ID = 1而不是回声荷兰国际集团的AGENT_ID,COUNTRY_ID和JOB_ID在他们的整数,我想输出自己的名字,而不是(Agent_Name,Country_Name,Job_Type)。

  1. 如何编写查询?
  2. 如何使用良好的$ result = mysql_query(“select ....”)在PHP中输出此信息; while($ row = mysql_fetch_query($ result)){echo .....};

回答

2

你需要加入表:

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连接到查询。

+0

对不起,不知道如何可以对这些结果在PHP :( – Felix 2009-08-22 18:28:50

+0

我已经编辑我原来的职位,以应付这一点。 – 2009-08-22 18:36:42

+0

谢谢谢谢谢谢! 这个工作,我爱StackOverflow的输出! – Felix 2009-08-22 18:47:02

0

只要在这里与JG一起使用连接。但是,这里有一个用于连接表的替代(并且更为接受的)语法。

SELECT A.Agent_Name, C.Country_Name, J.Job_Type 
FROM Line_Items LI 
INNER JOIN Agents A 
ON LI.Agent_ID = A.Agent_ID 
INNER JOIN Country C 
LI.Country_ID = C.Country_ID 
INNER JOIN Job J 
ON LI.Job_ID = J.Job_ID 
WHERE LI.Agent_ID = 1 

如果国家,代理或作业行可能不存在,则可以使用LEFT JOIN而不是内部联接。使用INNER JOIN,正如我所做的那样,如果没有国家,就不会返回行。

+0

因此,对于PHP输出,这应该工作? while($ row = mysql_fetch_array($ result)) { echo“Agent:”。 $ row ['A.Agent_Name']。“
”; 回声“国家:”。 $ row ['C.Country_Name']。“
”; 回声“工作:”。 $ row ['J.Job_Type']。“
”; } – Felix 2009-08-22 18:24:46

+0

使用var_dump($ row)查看$ row的内容。 – VolkerK 2009-08-22 18:35:08