我有一个查询:
SELECT Column1 FROM Table WHERE Column2 IN ('val1,'val2','val3',....'valn');
现在我想要那些没有返回任何行的值。表示我在 IN 函数中传递但它们不存在于我的表中的那些值。
对不起,如果我没有说清楚:)
SELECT x.f FROM
(SELECT 'val1' as f
UNION ALL
SELECT 'val2'
UNION ALL
SELECT 'val3') x
LEFT JOIN Table t ON x.f = t.Column2
WHERE t.Column2 IS NULL
我是这样做的:
$have_values = array('val1','val2'..... 'valn');
$i=0;
$have_values_string="";
foreach($have_values as $var => $val)
{
$have_values_string.="'".$val."'";
if($i!=count($have_values)-1) { $have_values_string.=",";}
$i++;
}
//now querying..
$sql=SELECT Column1 , Column2 FROM Table WHERE Column2 IN ('val1,'val2','val3',....'valn');
$result=mysql_query($sql);
while($row=mysql_fetch_array($result))
{
$found_values[$row[0]]=$row[1];
}
$not_found_values=array_diff($have_values, $found_values);