Avatar billede Nicolai Nybegynder
28. november 2013 - 15:24 Der er 2 kommentarer og
1 løsning

"NOT IN" Query giver ingen mening!

Hej,

Jeg har en udfordring som burde være simpel og nem at foklare, men jeg kan simpelthen ikke forstå at jeg ikke kan få dette her til at virke.

Jeg har problemer med at få en query til at vise mig det rigtige svar, hvorfor jeg har lavet 3 "test" queries for at finde ud af hvorfor den fejler. Derfor har jeg lavet følgende:

SELECT COUNT(Customer)
FROM dbo.tblXSAP_CUSTOMERS
WHERE
SGp IN ('581', '582', '583')
AND
RIGHT(Customer, 8) NOT IN (SELECT SHIPTO FROM dbo.tblXIST_DICT)
/*RESULTAT: 0 */

SELECT COUNT(Customer)
FROM dbo.tblXSAP_CUSTOMERS
WHERE
SGp IN ('581', '582', '583')
AND
RIGHT(Customer, 8) IN (SELECT SHIPTO FROM dbo.tblXIST_DICT)
/*RESULTAT: 7.044 */

SELECT COUNT(Customer)
FROM dbo.tblXSAP_CUSTOMERS
WHERE
SGp IN ('581', '582', '583')
/*RESULTAT: 7.114 */

Min logik fortæller mig at Query 1 + Query 2 bør være = Query 3 rent resultatmæssigt. Men som I kan se er det IKKE tilfældet?! Query 1 giver resultat '0', selvom jeg har en forventning om at den skulle give mig et resultat på '70' - forskellen på Query 3 og Query 2.

Er der nogen der kan komme med en forklaring?

Mange hilsener
Nicolai
Avatar billede Nicolai Nybegynder
28. november 2013 - 15:29 #1
Har lige testet med NOT EXIST og der virker det fint?! HVorfor?

SELECT COUNT(Customer)
FROM dbo.tblXSAP_CUSTOMERS
WHERE
SGp IN ('581', '582', '583')
AND
NOT EXISTS (SELECT SHIPTO FROM dbo.tblXIST_DICT WHERE RIGHT(Customer, 8) = SHIPTO)
/*RESULTAT: 70 */
Avatar billede Nicolai Nybegynder
28. november 2013 - 16:19 #2
Har identificeret at der formentlig er tale om at NOT EXIST ikke fejler på NULL values...

SÅ jeg lukker igen :)
Avatar billede arne_v Ekspert
28. november 2013 - 21:54 #3
NULL var ogsaa min foerste tanke.

Men det kan ikke passe, da COUNT(Customer) jo ikke taeller raekker hvor Customer er NULL.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Computerworld tilbyder specialiserede kurser i database-management

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester