0

我有一个查询:

SELECT Column1 FROM Table WHERE Column2 IN ('val1,'val2','val3',....'valn');

现在我想要那些没有返回任何行的值。表示我在 IN 函数中传递但它们不存在于我的表中的那些值。

对不起,如果我没有说清楚:)

4

2 回答 2

1
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
于 2012-08-12T20:37:14.960 回答
0

我是这样做的:

$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);
于 2012-08-21T13:37:37.033 回答