Fetstil Fetstil Kursiv Understrykning linje färgläggning tabellverk Punktlista Nummerlista Vänster Centrerat högerställt Utfyllt Länk Bild htmlmode
  • Forum & Blog
    • Forum - översikt
      • .Net
        • asp.net generellt
        • c#
        • vb.net
        • f#
        • silverlight
        • microsoft surface
        • visual studio .net
      • databaser
        • sql-server
        • databaser
        • access
        • mysql
      • mjukvara klient
        • datorer och komponenter
        • nätverk, lan/wan
        • operativsystem
        • programvaror
        • säkerhet, inställningar
        • windows server
        • allmänt
        • crystal reports
        • exchange/outlook
        • microsoft office
      • mjukvara server
        • active directory
        • biztalk
        • exchange
        • linux
        • sharepoint
        • webbservers
        • sql server
      • appar (win/mobil)
      • programspråk
        • c++
        • delphi
        • java
        • quick basic
        • visual basic
      • scripting
        • asp 3.0
        • flash actionscript
        • html css
        • javascript
        • php
        • regular expresssion
        • xml
      • spel och grafik
        • DirectX
        • Spel och grafik
      • ledning
        • Arkitektur
        • Systemutveckling
        • krav och test
        • projektledning
        • ledningsfrågor
      • vb-sektioner
        • activeX
        • windows api
        • elektronik
        • internet
        • komponenter
        • nätverk
        • operativsystem
      • övriga forum
        • arbete karriär
        • erbjuda uppdrag och tjänster
        • juridiska frågor
        • köp och sälj
        • matematik och fysik
        • intern information
        • skrivklåda
        • webb-operatörer
    • Posta inlägg i forumet
    • Chatta med andra
  • Konto
    • Medlemssida
    • Byta lösenord
    • Bli bonsumedlem
    • iMail
  • Material
    • Tips & tricks
    • Artiklar
    • Programarkiv
  • JOBB
  • Student
    • Studentlicenser
  • KONTAKT
    • Om pellesoft
    • Grundare
    • Kontakta oss
    • Annonsering
    • Partners
    • Felanmälan
  • Logga in

Hem / Forum översikt / inlägg

Posta nytt inlägg


Knepig sqlsats?

Postades av 2009-02-25 07:42:53 - Jonas Sjöblom, i forum mysq, Tråden har 4 Kommentarer och lästs av 1307 personer

Har 3 tabeller

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?


Svara

Sv: Knepig sqlsats?

Postades av 2009-02-25 10:36:49 - Johan Djupmarker

SELECT PageName FROM Pages WHERE PageID NOT IN(SELECT PageID FROM MenuLinks WHERE MenuID = 6)

/Johan


Svara

Sv:Knepig sqlsats?

Postades av 2009-02-25 10:59:32 - Jonas Sjöblom

Tack, jag sitter på jobbet nu så kan inte testa det men testar när jag kommer hem.

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?


Svara

Sv: Knepig sqlsats?

Postades av 2009-02-25 13:37:19 - Johan Djupmarker

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:

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


Svara

Sv:Knepig sqlsats?

Postades av 2009-02-25 17:02:30 - Jonas Sjöblom

Tackar nu fungerar det :)


Svara

Nyligen

  • 09:09 Vill du köpa medicinska tester?
  • 12:47 Vem beviljar assistansen – kommune
  • 14:17 Någon med erfarenhet av hemstädnin
  • 14:14 Bör man använda sig av en båtförme
  • 14:12 Finns det någon intressant hundblo
  • 14:25 Tips på verktyg för att skapa QR-k
  • 14:23 Tips på verktyg för att skapa QR-k
  • 20:52 Fungerer innskuddsbonuser egentlig

Sidor

  • Hem
  • Bli bonusmedlem
  • Läs artiklar
  • Chatta med andra
  • Sök och erbjud jobb
  • Kontakta oss
  • Studentlicenser
  • Skriv en artikel

Statistik

Antal besökare:
Antal medlemmar:
Antal inlägg:
Online:
På chatten:
4 569 153
27 952
271 704
807
0

Kontakta oss

Frågor runt konsultation, rådgivning, uppdrag, rekrytering, annonsering och övriga ärenden. Ring: 0730-88 22 24 | pelle@pellesoft.se

© 1986-2013 PelleSoft AB. Last Build 4.1.7169.18070 (2019-08-18 10:02:21) 4.0.30319.42000
  • Om
  • Kontakta
  • Regler
  • Cookies