Is it possible to negate a where clause?
e.g.
DELETE * FROM table WHERE id != 2;
I was just solving this problem. If you use <> or is not in on a variable, that is null, it will result in false. So instead of <> 1, you must check it like this:
AND (isdelete is NULL or isdelete = 0)
Yes. If memory serves me, that should work. Our you could use:
DELETE FROM table WHERE id <> 2
You can do like this
DELETE FROM table WHERE id NOT IN ( 2 )
OR
DELETE FROM table WHERE id <> 2
As @Frank Schmitt noted, you might want to be careful about the NULL values too. If you want to delete everything which is not 2(including the NULLs) then add OR id IS NULL to the WHERE clause.
Use <> to negate the where clause.