多个while循环无法正常工作

时间:2014-04-18 09:27:17

标签: php mysql join while-loop fetch

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            -

我在下面附上了示例图片和代码。

enter image description here

我希望有人能理解我的问题。在这里,我必须显示代理和驱动程序的详细信息。代理表具有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 }  } ?>

3 个答案:

答案 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

A fiddle Demo

答案 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:

http://sqlfiddle.com/#!2/52e28/9/0