AGENT DB TABLE
agent_id agent_name company_name
-------- ---------- -----------
1 AAA XXX
2 BBB YYY
3 CCC ZZZ
4 DDD XYZ
DRIVER DB TABLE
agent_id driver_id driver_name
-------- ---------- -----------
2 1 EEE
2 2 FFF
2 3 GGG
1 4 HHH
3 5 III
3 6 JJJ
我想表现出这样的结果
AGENT DETAILS DRIVER DETAILS
------------ --------------
1, AAA, XXX 1 Driver
2, BBB, YYY 3 Drivers
3, CCC, ZZZ 2 Drivers
4, DDD, XYZ 0 Driver
我已经尝试过,但我得到的结果就是这个
AGENT DETAILS DRIVER DETAILS
------------ --------------
1, AAA, XXX 1 Drivers
1, AAA, XXX 3 Drivers
1, AAA, XXX 2 Drivers
1, AAA, XXX -
我在下面附上了示例图片和代码。
我希望有人能理解我的问题。在这里,我必须显示代理和驱动程序的详细信息。代理表具有agent_id,agent_name,company_name。我想从代理表中获取所有记录。然后我想根据agent_id计算驱动程序的数量。
在我的驱动程序db表中,我有agent_id,driver_id,driver_name。我想基于agent_id从驱动程序表中获取驱动程序的数量。这是一个很好的工作。但是,我的问题是我有多个while循环因此它无法正常获取。请参阅我附上的图片。你可以轻松理解。在代理详细信息中,它始终在所有行中获取相同的行。
我确定我在while循环中犯了一个错误。但是,我不知道如何才能得到正确的结果。
<?php
$sql="select * from ".TBL_AGENT."";
$result=mysql_query($sql,$CN);
while($row=mysql_fetch_array($result))
{
$agentid = $row['agent_id'];
$agentname = $row['agent_name'];
$companyname = $row['company_name'];
$email = $row['email'];
$sql_query = mysql_query("SELECT agent_id, COUNT(driver_id) AS ".TBL_DRIVER." FROM ".TBL_DRIVER." GROUP BY $agentid"); while($rows = mysql_fetch_array($sql_query, MYSQL_ASSOC))
{ $noofdrivers = $rows['ta_drivers']. " DRIVERS"; echo "<br/>";
?>
<tr>
<td bgcolor="#FFFFFF" style="height: 70px; width: 300px; border-bottom: 1px solid #ccc; border-right: 1px solid #ccc;">
<b>Agent Name : </b><?=$agentname?><br /><br />
<b>Business Name : </b><?=$companyname?><br /><br />
<b>E-mail Id : </b><?=$email?>
</td>
<td bgcolor="#FFFFFF" style="height: 70px; border-bottom: 1px solid #ccc; border-right: 1px solid #ccc;">
<?php
echo $noofdrivers; ?>
</td>
<td bgcolor="#FFFFFF" style="height: 70px; border-bottom: 1px solid #ccc; border-right: 1px solid #ccc;"></td>
<td bgcolor="#FFFFFF" style="height: 70px; border-bottom: 1px solid #ccc;"></td>
</tr>
<?php } } ?>
答案 0 :(得分:2)
从评论这里得到答案,你可以加入你的表格并在php中循环它们
SELECT a.*,
COUNT(d.driver_id) `drivers_count`
FROM AGENT a
LEFT JOIN DRIVER d USING(agent_id)
GROUP BY a.agent_id
答案 1 :(得分:1)
SELECT a.agent_id,
a.agent_name,
a.company_name,
count(d.*) as count_of_drivers
FROM agent a, driver d
WHERE a.id_agent = d.id_agent
GROUP BY a.agent_id,
a.agent_name,
a.company_name
答案 2 :(得分:1)
使用一个带连接的查询(不要使用带昏迷的旧式连接)
SELECT agent.agent_id, agent.agent_name, agent.company_name, count(driver_id) as cnt
FROM agent left join driver on agent.agent_id = driver.agent_id
group by agent.agent_id
或者您可以使用此
SELECT agent_id, agent_name, company_name,
(Select count(*) FROM driver d WHERE d.agent_id = m.agent_id) AS cnt FROM agent m
这是可以理解的,但在大量数据上可能会慢一些
SQLfiddle: