2013-10-25 2 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 데이터를 그룹화하는 것입니다.

결과를 인쇄 할 때,이 waitingrooms JQuery와 아코디언으로 표시하며 각 대기실 아코디언의 사례 데이터를 표시하는 중첩 foreach 루프를 갖는다. 문제는 내가 전에 말했듯이, 대기실이 세 개가 아니라 두 개가 나타난다는 것입니다. 두 번째 및 세 번째 대기실 아코디언은 OK로 표시됩니다. 두 번째 아코디언에는 case_pk 1과 2가 표시되고 세 번째 아코디언에는 case_pk 3이 표시됩니다. 첫 번째 아코디언은 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 루프 아래에 있고, 잠시 후에 넣고 중첩 된 foreach를 사용하십시오. 작품 – developerCK

답변

1

후 루프 동안 그것을 사용하고 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