2013-04-11 60 views
0

in_array我有这样的代码:选择结果与SQL

$p = $db->query("SELECT ads_id FROM ads_submissions WHERE status = '0'"); 
$c_ads = array(); 
while($row = $db->fetchAll($p)) 
{ 
    $c_ads[] = $row; 
} 

输出

4 6 9 

我想这行添加到$ new_ads = $ DB->后WHERE

AND ads_id = !in_array('$output', $c_ads) 

若要选择除ID 4和6以外的所有ads_id和9

$new_ads = $db->fetchOne("SELECT ads_id FROM ads_pack WHERE allowed_countries LIKE '%".$country_tr."%'"); 

但是,这永远不能正常工作。

请帮忙吗?

谢谢。

+0

你的目标是?为什么选择状态为“0”的所有广告,然后选择全部不在此结果中?改变where子句不是更容易吗? – sailingthoms 2013-04-11 19:35:02

+0

@sailingthoms,OP引用两个查询中的不同表。虽然JOIN可能在这里工作。 – 2013-04-11 19:45:58

+0

使用连接肯定会有更好的方式和更高性能 – sailingthoms 2013-04-11 19:50:05

回答

1

你应该做这样的

AND ads_id NOT IN (implode(',', $c_ads)) 
1

在sql中没有这样的东西,如in array。只有结果集。你想

AND ads_id NOT IN (4,6,9) 
+0

所以我只需要使用AND ads_id而不是($ c_ads)而没有任何改变? – user2203703 2013-04-11 19:31:31

+0

好吧,你仍然需要内爆阵列。你不能直接在sql中嵌入一个PHP数组。例如'$ sql =“... WHERE field NOT IN(”。implode(',',$ array)。“)”'。 – 2013-04-11 19:33:14

0

你可以重写这个使用子查询,而不是运行2个查询?

"SELECT ads_id FROM ads_pack WHERE allowed_countries LIKE '%".$country_tr."%' AND ads_id NOT IN (SELECT ads_id FROM ads_submissions WHERE status = '0')"