0

次のMySQLクエリがあります:

$query_waitingrooms = "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')";
$result_waitingrooms = mysql_query($query_waitingrooms, $connection) or die(mysql_error()); 

結果は次のように表示されます。

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

予想どおり、これにより、アコーディオンごとに 1 つの「ケース」を含むテーブル「waitingroom_case_lookup」内の各レコードのアコーディオンが作成されます。私が求めているのは、「待合室」ごとにアコーディオンを作成し、それぞれにテーブル vcase とpatient からの関連する症例データを含めることです。

現時点で、テーブル「waitingroom_case_lookup」は次のとおりです。

CREATE TABLE waitingroom_case_lookup (
  waitingroom_case_lookup_pk int(9) NOT NULL AUTO_INCREMENT,
  waitingroom_fk int(3) NOT NULL,
  case_fk int(3) NOT NULL,
  PRIMARY KEY (waitingroom_case_lookup_pk)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1;

--
-- Dumping data for table 'waitingroom_case_lookup'
--

INSERT INTO waitingroom_case_lookup (waitingroom_case_lookup_pk, waitingroom_fk, case_fk) VALUES
(1, 1, 1),
(2, 1, 2),
(3, 2, 3);

<span class='text'>との間の各アコーディオン待合室でケースをループアウトする必要がある</p></div> ようです。これを行う方法について何か提案はありますか?

編集

NoBBY のおかげで、私は次の作業コードを持っています (まだフォーマットをクリーンアップする必要があります...):

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

    $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']
    );

 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>";
}
?>
4

1 に答える 1

1

データベースから結果を直接出力する代わりに、最初にフォーマットしてみてください。たとえば、次のようなことができます。

$waitingRooms = array();
while ($row_waitingrooms = mysql_fetch_assoc($result_waitingrooms)){
    $waitingRoomPK = $row_waitingrooms['waitingroom_pk'];

    if (!isset($waitingRooms[$waitingRoomPK])) {
        $waitingRooms[$waitingRoomPK] = array(
            'waitingroom_pk' => $waitingRoomPK,
            'waitingroom' => $row_waitingrooms['waitingroom'],
            'cases' => array(),
            //.....all the data for a waitingroom
        );
    }

    $waitingRooms[$waitingRoomPK]['cases'][] = array(
        'case_pk' => $row_waitingrooms['case_pk'],
        'patient_icon' => $row_waitingrooms['patient_icon'],
        'first_name' => $row_waitingrooms['first_name'],
        //.......all the data for a patient
    );
}

$waitingRooms は、各待合室のデータを含む配列であり、部屋の各患者のデータを含む「cases」サブ配列です。ここから、2 つの単純なネストされた foreach ステートメントが、アコーディオンに必要な html を出力します。

ただし、コードを改善する方法はいくつかあります。

  1. mysql_* 関数は使用しないでください。非推奨です。ドキュメントにあるこれらの巨大な赤い警告は、見た目だけのものではありません。ユーザー mysqli または PDO (両方ともドキュメントにリンクされています)
  2. 実際の結合を使用します。クエリの代替結合構文は読みやすさを損ないます
  3. SQL および HTML コードをフォーマットします。コード セグメントでこれらの水平スクロールバーを見たときに、多くの人があなたの質問をスキップしたに違いありません

次のことに同意していただければ幸いです。

<?php while($row_waitingrooms = mysql_fetch_assoc($result_waitingrooms)): ?>
<h6><?= $row_waitingrooms['waitingroom']; ?></h6>
<div>
    <p>
        <span class='text'>
            <table width='100%'>
                <tr>
                    <td>
                        <input name='case' id='case_<?= $row_waitingrooms['case_pk']; ?>' type='radio' value='<?= $row_waitingrooms['case_pk']; ?>' />
                    </td>
                    <td width='65' align='left'>
                        <div class='case_list'>
                            <img src='images/case_icons/<?= $row_waitingrooms['patient_icon']; ?>'  width='44' height='45' />
                        </div>
                    </td>
                    <td width='350'  align='left'>
                        <?= $row_waitingrooms['first_name'] . ' ' . $row_waitingrooms['last_name']; ?>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                        Gender: <?= $row_waitingrooms['gender']; ?>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;
                        Age: <?= $row_waitingrooms['age']; ?>
                        <br />
                        Presenting Complaint: <?= $row_waitingrooms['presenting_complaint']; ?>
                    </td>
                </tr>
            </table>
    </p>
</div>
<?php endwhile; ?>

それよりもはるかに優れています:

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

そして、閉じられていないスパンタグを見るボーナスを得ます:)

于 2013-10-23T12:00:39.510 に答える