2013-10-25 204 views
0

我正在尝试执行多表查询并将结果包含到特定表中的记录。我敢肯定,这不是很清楚,所以这里有与相关领域的表:MySQL查询分组结果

waitingroom 
    +----------------+-------------+ 
    | waitingroom_pk | waitingroom | 
    +----------------+-------------+ 
    |   1  | PATH2201 | 
    +----------------+-------------+ 
    |   2  | PATH2202 | 
    +----------------+-------------+ 

waitingroom_case_lookup 
    +----------------------------+----------------+---------+ 
    | waitingroom_case_lookup_pk | waitingroom_fk | case_fk | 
    +----------------------------+----------------+---------+ 
    |   1     | 1   | 1  | 
    +----------------------------+----------------+---------+ 
    |   2     | 1   | 2  | 
    +----------------------------+----------------+---------+ 
    |   3     | 2   | 3  | 
    +----------------------------+----------------+---------+ 
vcase 
    +---------+------------+------------+ 
    | case_pk | case_title | patient_fk | 
    +---------+------------+------------+ 
    | 1 | Case One |  1  | 
    +---------+------------+------------+ 
    | 2 | Case Two |  2  | 
    +---------+------------+------------+ 
    | 3 | Case Three |  3  | 
    +---------+------------+------------+ 

    patient 
    +------------+------------+-----------+---------+ 
    | patient_pk | first_name | last_name | case_fk | 
    +------------+------------+-----------+---------+ 
    | 1   | John  | Smith  | 1  | 
    +------------+------------+-----------+---------+ 
    | 2   | Will  | Jones  | 2  | 
    +------------+------------+-----------+---------+ 
    | 3   | Mary  | Ryan  | 3  | 
    +------------+------------+-----------+---------+ 

,我使用的查询是:

SELECT * FROM 
waitingroom, waitingroom_case_lookup, vcase, patient 
WHERE vcase.patient_fk = patient.patient_pk 
AND waitingroom.waitingroom_pk = waitingroom_case_lookup.waitingroom_fk 
AND vcase.case_pk = waitingroom_case_lookup.case_fk 
AND vcase.active = 'y' 
AND vcase.case_pk NOT IN (SELECT case_fk FROM user_case_lookup WHERE user_id = '$user_id') 

该查询返回结果显示三个waitingrooms代替两个,大概是因为表waitingroom_case_lookup中有三条记录。我想要的是根据使用waitingroom_case_lookup的等候室对vcase数据进行分组。

至于打印结果,候车室显示为JQuery手风琴,我有一个嵌套的foreach循环,它显示每个候车室手风琴中的案例数据。正如我之前所说的那样,问题在于三个候车室不是两个。第二和第三等候室手风琴似乎没问题,case_pk一号和二号在第二个手风琴中展示,case_pk三个在第三个展示。第一个手风琴也展示了case_pk,这个手风琴不应该展示。

<?php 
$waitingRooms = array(); 

while ($row_waitingrooms = mysql_fetch_assoc($result_waitingrooms)){ 

     if($row_waitingrooms['gender'] == 'f'){ 
       $gender = 'Female'; 
      } else if ($row_waitingrooms['gender'] == 'm'){ 
       $gender = 'Male'; 
      } 

     $waitingRoomPK = $row_waitingrooms['waitingroom_pk']; 

     if (!isset($waitingRooms[$waitingRoomPK])) { 
      $waitingRooms[$waitingRoomPK] = array(
       'waitingroom_pk' => $waitingRoomPK, 
       'waitingroom' => $row_waitingrooms['waitingroom'], 
       'cases' => array() 
      ); 
     } 

     $waitingRooms[$waitingRoomPK]['cases'][] = array(
      'case_pk' => $row_waitingrooms['case_pk'], 
      'patient_icon' => $row_waitingrooms['patient_icon'], 
      'first_name' => $row_waitingrooms['first_name'], 
      'last_name' => $row_waitingrooms['last_name'], 
      'age' => $row_waitingrooms['age'], 
      'gender' => $gender, 
      'presenting_complaint' => $row_waitingrooms['presenting_complaint'] 
     ); 



    echo "<h6>" . $row_waitingrooms['waitingroom'] . "</h6><div><p><span class='text'>"; 

    foreach ($waitingRooms[$waitingRoomPK]['cases'] as $wcase){ 
     echo "<table width='100%'><tr><td><input name='case' id='case_" . $wcase['case_pk'] . "' type='radio' value='" . $wcase['case_pk'] . "' /></td><td width='65' align='left'><div class='case_list'><img src='images/case_icons/" . $wcase['patient_icon'] . "' width='44' height='45' /></div></td><td width='350' align='left'>" . $wcase['first_name'] . ' ' . $wcase['last_name'] . '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbspGender: ' . $wcase['gender'] . '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Age: ' . $wcase['age'] . '<br />Presenting Complaint: ' . $wcase['presenting_complaint'] . "</td></tr></table>"; 
     } 
    echo "</span></p></div>"; 
    } 
    ?> 

我怀疑查询需要改变分组的情况下数据手风琴的waitingrooms表,任何想法如何,我应该这样做:

结果使用下面的代码打印?

编辑

感谢developerCK我现在有以下工作代码:

<?php 
while ($row_waitingrooms = mysql_fetch_assoc($result_waitingrooms)){ 

    if($row_waitingrooms['gender'] == 'f'){ 
      $gender = 'Female'; 
     } else if ($row_waitingrooms['gender'] == 'm'){ 
      $gender = 'Male'; 
     } 

    $waitingRoomPK = $row_waitingrooms['waitingroom_pk']; 

    if (!isset($waitingRooms[$waitingRoomPK])) { 
     $waitingRooms[$waitingRoomPK] = array(
      'waitingroom_pk' => $waitingRoomPK, 
      'waitingroom' => $row_waitingrooms['waitingroom'], 
      'cases' => array() 
     ); 
    } 

    $waitingRooms[$waitingRoomPK]['cases'][] = array(
     'case_pk' => $row_waitingrooms['case_pk'], 
     'patient_icon' => $row_waitingrooms['patient_icon'], 
     'first_name' => $row_waitingrooms['first_name'], 
     'last_name' => $row_waitingrooms['last_name'], 
     'age' => $row_waitingrooms['age'], 
     'gender' => $gender, 
     'presenting_complaint' => $row_waitingrooms['presenting_complaint'] 
    ); 

} 

foreach($waitingRooms as $val){ 

echo "<h6>" . $val['waitingroom'] . "</h6><div><p><span class='text'>"; 

    foreach ($val['cases'] as $wcase){ 
     echo "<table width='100%'><tr><td><input name='case' id='case_" . $wcase['case_pk'] . "' type='radio' value='" . $wcase['case_pk'] . "' /></td><td width='65' align='left'><div class='case_list'><img src='images/case_icons/" . $wcase['patient_icon'] . "' width='44' height='45' /></div></td><td width='350' align='left'>" . $wcase['first_name'] . ' ' . $wcase['last_name'] . '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbspGender: ' . $wcase['gender'] . '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Age: ' . $wcase['age'] . '<br />Presenting Complaint: ' . $wcase['presenting_complaint'] . "</td></tr></table>"; 
     } 
    echo "</span></p></div>"; 
} 

?> 
+0

你可以做一个SQL小提琴吗? – developerCK

+0

http://sqlfiddle.com/#!2/10e93/1 – IlludiumPu36

+0

你的查询和php代码是正确的,只是,你的foreach循环在while循环之下,把它放在while后面并使用嵌套的foreach.and让我知道它是否作品 – developerCK

回答

1

使用while循环后,并删除foreach循环。 你的查询是正确的。只需要改变一些PHP代码

foreach(waitingRooms as $val){ 

echo "<h6>" . $val['waitingroom'] . "</h6><div><p><span class='text'>"; 

    foreach ($val['cases'] as $wcase){ 
     echo "<table width='100%'><tr><td><input name='case' id='case_" . $wcase['case_pk'] . "' type='radio' value='" . $wcase['case_pk'] . "' /></td><td width='65' align='left'><div class='case_list'><img src='images/case_icons/" . $wcase['patient_icon'] . "' width='44' height='45' /></div></td><td width='350' align='left'>" . $wcase['first_name'] . ' ' . $wcase['last_name'] . '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbspGender: ' . $wcase['gender'] . '&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;Age: ' . $wcase['age'] . '<br />Presenting Complaint: ' . $wcase['presenting_complaint'] . "</td></tr></table>"; 
     } 
    echo "</span></p></div>"; 
} 
+0

developerCK - 非常感谢,完美的作品 - 请参阅OP编辑中的工作代码。 – IlludiumPu36