0

PHP ID を持つ 2 つのテーブルから取り込まれた 2 つの単一配列があります。1 つの配列から、X 個以上の数値が表示されている同じ値のすべての ID を削除できる必要があります。私はこれをやっています:

volunteerRoleQuery = mysql_query("SELECT member_no, role_code, volunteer_date FROM         evntrole WHERE volunteer_date > '$today' ");
$numberEvntRole = mysql_numrows($volunteerRoleQuery);

while ($row = mysql_fetch_assoc($volunteerRoleQuery)) {
    $member_no = $row["member_no"];
    array_push($volunteersArray, $member_no);
}

fputcsv($output, array('Member number', 'Full name', 'First name', 'Surname', 'Email', 'Mobile', 'Phone'));

$teamMemQuery = mysql_query("SELECT member_number, activity_code, modify_date FROM  teammem WHERE modify_date > '$today' ");
    $numberTeamMem = mysql_numrows($teamMemQuery);

if ($numberTeamMem > 0) {
    while ($row = mysql_fetch_assoc($teamMemQuery)) {
        $member_no = $row["member_number"];
        array_push($teamMemArray, $member_no);        
    }
}

//todo: 3 など、x 個を超えるイベントを持つメンバー ID のみを保持します。これにより、少数のイベントのみを行った場合でも、メンバーにボランティアを依頼することはありません。

$result=array_unique($teamMemArray);

array_diff_ORG_NEW($teamMemArray,$volunteersArray, 'VALUES');

$result=array_unique($teamMemArray);
sort($result);
foreach ($result as &$value) {
        $resultNames = mysql_query("SELECT first_name, surname, mobile, phone_home, e_mail  FROM names WHERE member_no='$value'");
        $rowNames = mysql_fetch_array($resultNames);
        $firstName = $rowNames['first_name'];
        $surname = $rowNames['surname'];

            if ($surname > "") {
                fputcsv($output, array($value, $names, $firstName, $surname, $email, $mobile, $homePhone));
        }
}
4

1 に答える 1

0

必要なものを正しく理解したかどうかはわかりませんが、 PHP のarray_count_valuesを調べましたか?

キーワードに一致するものがいくつあるかを示す別の配列が表示されます。

それをループして、Xより大きい結果のキーを削除することができますか?

于 2013-03-20T00:17:03.903 に答える