内部結合を使用してSQLクエリを実行しようとしています...コードは以下のとおりです...パート1は正常に機能し、$ query_adlistの値を動的に作成しています..しかし、パート2でこの変数$ query_adlistを使用すると、結果をフェッチしません。
パート1。
$query_adlist="";
$ad_list_countx=mysql_query("SELECT COUNT(ads_id) FROM ads WHERE id=$id");
if($ad_list_countx){$ad_list_count=mysql_fetch_row($ad_list_countx);}
if(isset($ad_list_count) && $ad_list_count[0] > 0)
{
$query_adlist .="&& (";
$query_ad_listx=mysql_query("SELECT ads_id FROM ads WHERE id=$id");
if(isset($query_ad_listx))
{
$sign=" || ";
$count=1;
while($query_ad_list=mysql_fetch_array($query_ad_listx))
{ if($ad_list_count[0] == $count){$sign=") &&";}
$query_adlist .="ad_clicks.ads_id=".$query_ad_list['ads_id'].$sign;
$count++;
}
}
}
whileループ後のこの変数の値は
$query_adlist="&& (ad_clicks.ad_id=44 || ad_clicks.ad_id=43)";
パート2。パート2のコードを実行すると、結果がフェッチされません。ただし、ad_clicks.ad_id = 44と入力すると|| ad_clicks.ad_id = 43変数$ query_adlistの代わりに、結果をフェッチします。混乱しています。何が間違っているのか。
$daily_clickx1=mysql_query("
SELECT COUNT(ad_clicks.ad_id) FROM ad_clicks
INNER JOIN members ON ad_clicks.id=members.id
WHERE members.ref_id1=$id
&& ad_clicks.date='$date_modified' $query_adlist
");
まあそれは私の間違いでした..列名が間違っていました..後でそれを理解しました。列名ads_idは実際にはad_idでした
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加