Har 3 tabeller SELECT PageName FROM Pages WHERE PageID NOT IN(SELECT PageID FROM MenuLinks WHERE MenuID = 6) Tack, jag sitter på jobbet nu så kan inte testa det men testar när jag kommer hem. WHERE-satsen ger ingen träff på NULL-värden. Sähär ska du göra iställt, det är mycket bättre än mitt första förslag:Knepig sqlsats?
Menu
MenuID
MenuLinks
MenuLinkID (Irrellevant här)
MenuID
PageID
Pages
PageID
PageName
Nu vill jag selecta PageName för alla pages som INTE är kopplade till en meny med ID 6 men kommer inte på hur jag ska skriva det. Notera att inte alla sidor (Page) är kopplade till någon meny.
Jag har föröskt med något i stil med
SELECT PageName FROM Pages p
LEFT JOIN MenuLinks ml ON p.PageID = ml.PageID
WHERE NOT p.PageID = 6
Men då visas bara sidor som är kopplade till menulinks och inte har ID 6. Jag förlorar alltså dom som inte är kopplade till någon meny.
Ska jag vara ärlig så har jag aldrig förstått left och right join ordentligt, kanske jag går till väga på fel sätt här?Sv: Knepig sqlsats?
/JohanSv:Knepig sqlsats?
Av nyfikenhet, varför fungerade dte inte med left join?
Om jag förstått det rätt så borde den lista alla rader i pages och endast länka in rader från menulinks när det finns match, annars ge null på dom?Sv: Knepig sqlsats?
SELECT PageName FROM Pages p
LEFT JOIN MenuLinks ml ON p.PageID = ml.PageID
WHERE <b>NOT ml.MenuID = 6 OR ml.MenuID IS NULL</b>
Om du får problem med flera identiska träffar får du gruppera:
SELECT PageName FROM Pages p
LEFT JOIN MenuLinks ml ON p.PageID = ml.PageID
WHERE NOT ml.MenuID = 6 OR ml.MenuID IS NULL
GROUP BY PageName, p.PageID
/Johan