Risposte:
Che tipo di campo è questo? L'operatore IN non può essere utilizzato con un singolo campo, ma deve essere utilizzato in sottoquery o con elenchi predefiniti:
-- subquery
SELECT a FROM x WHERE x.b NOT IN (SELECT b FROM y);
-- predefined list
SELECT a FROM x WHERE x.b NOT IN (1, 2, 3, 6);
Se stai cercando una stringa, scegli l'operatore LIKE (ma sarà lento):
-- Finds all rows where a does not contain "text"
SELECT * FROM x WHERE x.a NOT LIKE '%text%';
Se lo limiti in modo tale che la stringa che stai cercando debba iniziare con quella data, può usare gli indici (se c'è un indice su quel campo) ed essere ragionevolmente veloce:
-- Finds all rows where a does not start with "text"
SELECT * FROM x WHERE x.a NOT LIKE 'text%';
NOT IN
nessuno dei valori sarà NULL, poiché NOT IN e NULL non si combinano in modo ovvio se non si ha familiarità con la logica a tre valori. Qui useresti SELECT a FROM x WHERE x.b NOT IN (SELECT b FROM y WHERE b IS NOT NULL);
Se dovessi anche escludere i valori NULL, dovresti fare questo:SELECT a FROM x WHERE x.b NOT IN (SELECT b FROM y WHERE b IS NOT NULL) AND x.b IS NOT NULL;
SELECT * FROM table WHERE field1 NOT LIKE '%$x%';
(Assicurati di scappare $ x correttamente prima per evitare l'iniezione SQL)
Modifica: NOT IN
fa qualcosa di leggermente diverso - la tua domanda non è del tutto chiara, quindi scegli quale usare. LIKE 'xxx%'
può usare un indice. LIKE '%xxx'
o LIKE '%xxx%'
no.