クエリは正しくソートされていますが、すべての結果が適切に表示されていません

このクエリは動作しますが、私は奇妙なバグがあるようです。 users表の最初のユーザーは、他のすべてのユーザーが関連するすべてのヘルプ問題をすべて表示できます。しかし、データベース内の2番目のユーザーは、最初のユーザーがヘルプの質問を出すことができ、その2番目のユーザーのテーブル内の他の人の結果は無視されます。

私はそれが括弧と関係があると思いますか?

コード:

//Unseen
$variis = "Need Help";
$myid = "This is the user's id;"

$sql = "select car_help.car_id, agent_names.agent_name, help_box.status, 
car_help.why_car, car_help.date_time_added, car_help.just_date, 
car_help.type, agent_names.agent_id
from car_help LEFT JOIN agent_names on car_help.agent_whois = agent_names.agent_id 
where agent_names.system_id = '$myid' and car_help.system_id='$myid' 
and added_by <> '$myid' and help_box.status = '$variis'
UNION
select magazine_help.note_id, agent_names.agent_name, help_box.status, 
magazine_help.note_name, magazine_help.date_time_added, 
magazine_help.just_date, magazine_help.type, agent_names.agent_id
from magazine_help LEFT JOIN agent_names on 
magazine_help.agent_id = agent_names.agent_id 
where agent_names.system_id='$myid' and 
magazine_help.system_id = '$myid' and added_by <> '$myid' 
and help_box.status = '$variis'
UNION
select motorcycle_help.rand_id, agent_names.agent_name, 
help_box.status, motorcycle_help.rand_name, motorcycle_help.date_time_added,     
motorcycle_help.just_date, motorcycle_help.type, agent_names.agent_id
from motorcycle_help LEFT JOIN agent_names ON 
motorcycle_help.by_who = agent_names.agent_id
where agent_names.system_id = '$myid' and 
motorcycle_help.system_id='$myid' and added_by <> '$myid' 
and help_box.status = '$variis'
UNION
select mobile_questions.bal_test_id, agent_names.agent_name, 
help_box.status, mobile_questions.bal_why, mobile_questions.date_time_added,   
mobile_questions.just_date, mobile_questions.type, agent_names.agent_id
from mobile_questions LEFT JOIN agent_names ON 
mobile_questions.agent_who_ordered = agent_names.agent_id
where agent_names.system_id = '$myid' and 
mobile_questions.system_id='$myid' and added_by <> '$myid' 
and help_box.status = '$variis'
ORDER BY date_time_added DESC LIMIT $startrow, 20";

$result = mysql_query($sql);

$query = mysql_query($sql) or die ("Error: ".mysql_error());


if ($result == "")
{
echo "";
}
echo "";


$rows = mysql_num_rows($result);

if($rows == 0)
{
print("");

}
elseif($rows > 0)
{
while($row = mysql_fetch_array($query))
{

$row1 = $row['row_name'];


print("$row1");
}

}
1

1 答え

where agent_names.system_id = '$myid' and 
motorcycle_help.system_id='$myid' and added_by <> '$myid' 
and help_box.status = '$variis'

すべてが true の場合にのみデータを返します。 2番目の人物が3つのフィールドすべてに一致するIDを持っていない場合、それはあなたの期待するものを返さないでしょう。 $ variis が空の場合、呼び出し変数を置き換えるデフォルトのIDを作成します。 aまたはステートメントが必要な場合があります。エコースティックを使うつもりなら、同じことが印刷されます。

1
追加された
それは実際に働いた。私は各クエリからagent_names.system_id = '$ myid'を削除しました。あなたが一度だけそれに答えることを試みた唯一の人だから、あなたの答えを選んでください。ありがとう。
追加された 著者 AAA,
PHP - 日本のコミュニティ [ja]
PHP - 日本のコミュニティ [ja]
4 参加者の

このグループではPHPについて話します。 パートナー:kotaeta.com