En join-sats används för att fråga data över flera relaterade tabeller.
Nu när vi har skapat en relation mellan två tabeller kan vi nu använda båda tabellerna inom en enda SELECT
uttalande för att returnera relaterade data. Vi kan göra detta med en JOIN
uttalande.
Vi kommer att fråga våra tabeller med hjälp av de tre huvudsakliga jointyperna:
- Inre koppling
- Left Outer Join
- Korsanslutning
The Inner Join
En inre join är en join där värdena i kolumnerna som sammanfogas jämförs med en jämförelseoperator. I SQL-standarden kan inner joins anges i antingen FROM
eller WHERE
klausul.
Till exempel kan vi köra en fråga för att hämta en lista över alla artister och deras album:
SELECT ArtistName, AlbumName FROM Artists AS a INNER JOIN Albums AS b ON a.ArtistId = b.ArtistId ORDER BY ArtistName;
Resultat:
ArtistName AlbumName ------------ -------------------- Iron Maiden Killers Iron Maiden Powerslave Iron Maiden Somewhere in Time Joe Satriani Surfing with the Ali Joe Satriani Flying in a Blue Dre Joe Satriani Black Swans and Worm Mr Percival Out of the Loop Primus Suck on This Primus Pork Soda Primus Sailing the Seas of Strapping Yo Heavy as a Really He The Wiggles Yummy Yummy The Wiggles Big Red Car
Du kanske har märkt att kolumnerna ovan inte är tillräckligt breda för vår nya data (en del av data trunkeras). För att visa all data måste vi öka kolumnstorlekarna igen.
Något som .width 20 50
borde räcka för nu.
Vi kan också använda en WHERE
klausul för att begränsa resultaten till en viss artist:
SELECT b.AlbumName FROM Artists AS a INNER JOIN Albums AS b ON a.ArtistId = b.ArtistId WHERE a.ArtistName = 'The Wiggles';
AlbumName -------------------- Yummy Yummy Big Red Car
Men WHERE
kunde enkelt ha varit en AND
för att utöka ON
klausul:
SELECT b.AlbumName FROM Artists AS a INNER JOIN Albums AS b ON a.ArtistId = b.ArtistId AND a.ArtistName = 'The Wiggles';
The Left Outer Join
En yttre koppling returnerar alla rader från minst en av tabellerna eller vyerna som nämns i FROM
sats, så länge som dessa rader möter någon WHERE
eller HAVING
sökvillkor.
Med vänster yttre koppling, alla rader hämtas från den vänstra tabellen som refereras till.
Så i följande exempel, alla rader från Artister tabeller returneras, oavsett om det finns en relaterad post i Album bord.
SELECT a.ArtistName, b.AlbumName FROM Artists AS a LEFT OUTER JOIN Albums AS b ON a.ArtistId = b.ArtistId;
Resultat:
ArtistName AlbumName -------------------- -------------------------------------------------- Joe Satriani Black Swans and Wormhole Wizards Joe Satriani Flying in a Blue Dream Joe Satriani Surfing with the Alien Steve Vai The Tea Party Noiseworks Wayne Jury Mr Percival Out of the Loop Iron Maiden Killers Iron Maiden Powerslave Iron Maiden Somewhere in Time Atmasphere Ian Moss Magnum Strapping Young Lad Heavy as a Really Heavy Thing Slayer Primus Pork Soda Primus Sailing the Seas of Cheese Primus Suck on This Pat Metheny Frank Gambale Frank Zappa The Wiggles Big Red Car The Wiggles Yummy Yummy
The Cross Join
En korskoppling (som inte har en WHERE
klausul) resulterar i den kartesiska produkten av tabellerna som är involverade i sammanfogningen. Därför är storleken på resultatuppsättningen antalet rader i den första tabellen multiplicerat med antalet rader i den andra tabellen.
Var försiktig med korsfogen. Det kan returnera extremt stora resultatuppsättningar!
SELECT ArtistName, AlbumName FROM Artists AS a CROSS JOIN Albums AS b ORDER BY ArtistName;
Resultat (du måste förmodligen rulla):
ArtistName AlbumName -------------------- -------------------------------------------------- Atmasphere Killers Atmasphere Powerslave Atmasphere Surfing with the Alien Atmasphere Heavy as a Really Heavy Thing Atmasphere Yummy Yummy Atmasphere Out of the Loop Atmasphere Suck on This Atmasphere Pork Soda Atmasphere Sailing the Seas of Cheese Atmasphere Flying in a Blue Dream Atmasphere Black Swans and Wormhole Wizards Atmasphere Somewhere in Time Atmasphere Big Red Car Frank Gambale Killers Frank Gambale Powerslave Frank Gambale Surfing with the Alien Frank Gambale Heavy as a Really Heavy Thing Frank Gambale Yummy Yummy Frank Gambale Out of the Loop Frank Gambale Suck on This Frank Gambale Pork Soda Frank Gambale Sailing the Seas of Cheese Frank Gambale Flying in a Blue Dream Frank Gambale Black Swans and Wormhole Wizards Frank Gambale Somewhere in Time Frank Gambale Big Red Car Frank Zappa Killers Frank Zappa Powerslave Frank Zappa Surfing with the Alien Frank Zappa Heavy as a Really Heavy Thing Frank Zappa Yummy Yummy Frank Zappa Out of the Loop Frank Zappa Suck on This Frank Zappa Pork Soda Frank Zappa Sailing the Seas of Cheese Frank Zappa Flying in a Blue Dream Frank Zappa Black Swans and Wormhole Wizards Frank Zappa Somewhere in Time Frank Zappa Big Red Car Ian Moss Killers Ian Moss Powerslave Ian Moss Surfing with the Alien Ian Moss Heavy as a Really Heavy Thing Ian Moss Yummy Yummy Ian Moss Out of the Loop Ian Moss Suck on This Ian Moss Pork Soda Ian Moss Sailing the Seas of Cheese Ian Moss Flying in a Blue Dream Ian Moss Black Swans and Wormhole Wizards Ian Moss Somewhere in Time Ian Moss Big Red Car Iron Maiden Killers Iron Maiden Powerslave Iron Maiden Surfing with the Alien Iron Maiden Heavy as a Really Heavy Thing Iron Maiden Yummy Yummy Iron Maiden Out of the Loop Iron Maiden Suck on This Iron Maiden Pork Soda Iron Maiden Sailing the Seas of Cheese Iron Maiden Flying in a Blue Dream Iron Maiden Black Swans and Wormhole Wizards Iron Maiden Somewhere in Time Iron Maiden Big Red Car Joe Satriani Killers Joe Satriani Powerslave Joe Satriani Surfing with the Alien Joe Satriani Heavy as a Really Heavy Thing Joe Satriani Yummy Yummy Joe Satriani Out of the Loop Joe Satriani Suck on This Joe Satriani Pork Soda Joe Satriani Sailing the Seas of Cheese Joe Satriani Flying in a Blue Dream Joe Satriani Black Swans and Wormhole Wizards Joe Satriani Somewhere in Time Joe Satriani Big Red Car Magnum Killers Magnum Powerslave Magnum Surfing with the Alien Magnum Heavy as a Really Heavy Thing Magnum Yummy Yummy Magnum Out of the Loop Magnum Suck on This Magnum Pork Soda Magnum Sailing the Seas of Cheese Magnum Flying in a Blue Dream Magnum Black Swans and Wormhole Wizards Magnum Somewhere in Time Magnum Big Red Car Mr Percival Killers Mr Percival Powerslave Mr Percival Surfing with the Alien Mr Percival Heavy as a Really Heavy Thing Mr Percival Yummy Yummy Mr Percival Out of the Loop Mr Percival Suck on This Mr Percival Pork Soda Mr Percival Sailing the Seas of Cheese Mr Percival Flying in a Blue Dream Mr Percival Black Swans and Wormhole Wizards Mr Percival Somewhere in Time Mr Percival Big Red Car Noiseworks Killers Noiseworks Powerslave Noiseworks Surfing with the Alien Noiseworks Heavy as a Really Heavy Thing Noiseworks Yummy Yummy Noiseworks Out of the Loop Noiseworks Suck on This Noiseworks Pork Soda Noiseworks Sailing the Seas of Cheese Noiseworks Flying in a Blue Dream Noiseworks Black Swans and Wormhole Wizards Noiseworks Somewhere in Time Noiseworks Big Red Car Pat Metheny Killers Pat Metheny Powerslave Pat Metheny Surfing with the Alien Pat Metheny Heavy as a Really Heavy Thing Pat Metheny Yummy Yummy Pat Metheny Out of the Loop Pat Metheny Suck on This Pat Metheny Pork Soda Pat Metheny Sailing the Seas of Cheese Pat Metheny Flying in a Blue Dream Pat Metheny Black Swans and Wormhole Wizards Pat Metheny Somewhere in Time Pat Metheny Big Red Car Primus Killers Primus Powerslave Primus Surfing with the Alien Primus Heavy as a Really Heavy Thing Primus Yummy Yummy Primus Out of the Loop Primus Suck on This Primus Pork Soda Primus Sailing the Seas of Cheese Primus Flying in a Blue Dream Primus Black Swans and Wormhole Wizards Primus Somewhere in Time Primus Big Red Car Slayer Killers Slayer Powerslave Slayer Surfing with the Alien Slayer Heavy as a Really Heavy Thing Slayer Yummy Yummy Slayer Out of the Loop Slayer Suck on This Slayer Pork Soda Slayer Sailing the Seas of Cheese Slayer Flying in a Blue Dream Slayer Black Swans and Wormhole Wizards Slayer Somewhere in Time Slayer Big Red Car Steve Vai Killers Steve Vai Powerslave Steve Vai Surfing with the Alien Steve Vai Heavy as a Really Heavy Thing Steve Vai Yummy Yummy Steve Vai Out of the Loop Steve Vai Suck on This Steve Vai Pork Soda Steve Vai Sailing the Seas of Cheese Steve Vai Flying in a Blue Dream Steve Vai Black Swans and Wormhole Wizards Steve Vai Somewhere in Time Steve Vai Big Red Car Strapping Young Lad Killers Strapping Young Lad Powerslave Strapping Young Lad Surfing with the Alien Strapping Young Lad Heavy as a Really Heavy Thing Strapping Young Lad Yummy Yummy Strapping Young Lad Out of the Loop Strapping Young Lad Suck on This Strapping Young Lad Pork Soda Strapping Young Lad Sailing the Seas of Cheese Strapping Young Lad Flying in a Blue Dream Strapping Young Lad Black Swans and Wormhole Wizards Strapping Young Lad Somewhere in Time Strapping Young Lad Big Red Car The Tea Party Killers The Tea Party Powerslave The Tea Party Surfing with the Alien The Tea Party Heavy as a Really Heavy Thing The Tea Party Yummy Yummy The Tea Party Out of the Loop The Tea Party Suck on This The Tea Party Pork Soda The Tea Party Sailing the Seas of Cheese The Tea Party Flying in a Blue Dream The Tea Party Black Swans and Wormhole Wizards The Tea Party Somewhere in Time The Tea Party Big Red Car The Wiggles Killers The Wiggles Powerslave The Wiggles Surfing with the Alien The Wiggles Heavy as a Really Heavy Thing The Wiggles Yummy Yummy The Wiggles Out of the Loop The Wiggles Suck on This The Wiggles Pork Soda The Wiggles Sailing the Seas of Cheese The Wiggles Flying in a Blue Dream The Wiggles Black Swans and Wormhole Wizards The Wiggles Somewhere in Time The Wiggles Big Red Car Wayne Jury Killers Wayne Jury Powerslave Wayne Jury Surfing with the Alien Wayne Jury Heavy as a Really Heavy Thing Wayne Jury Yummy Yummy Wayne Jury Out of the Loop Wayne Jury Suck on This Wayne Jury Pork Soda Wayne Jury Sailing the Seas of Cheese Wayne Jury Flying in a Blue Dream Wayne Jury Black Swans and Wormhole Wizards Wayne Jury Somewhere in Time Wayne Jury Big Red Car
Men om en WHERE
sats läggs till, korsfogningen beter sig som en inre sammanfogning.
Andra anslutningstyper
SQL-standarden inkluderar även RIGHT OUTER JOIN
och FULL OUTER JOIN
SQLite stöder dock inte dessa jointyper.