Kursinnehåll
Intermediär SQL
Intermediär SQL
Nästlade Frågor
Skoladministrationen är nöjd med våra senaste prestationer och är ivrig att gå vidare.
När de börjar sitt sommarlov har vi chansen att utforska nya metoder och förbättra våra SQL-färdigheter.
Vårt fokus kommer att ligga på nästlade frågor, ett nyckelbegrepp i SQL.
Låt oss titta på ett exempel från vår företagsdatabas. När företaget växer har vi lagt till en ny department
-tabell. Detta förändrar hur vår databas fungerar.
Låt oss kolla in den nya tabellens struktur för att se dess roll i vår databas:
Den nya tabellen innehåller avdelningar, deras typer och budgetar. Och i employee
-tabellen, som du kanske minns, finns det information om vilken avdelning varje anställd tillhör.
Låt oss överväga ett exempel där vi använder nästlade frågor för att hämta de anställda som arbetar i avdelningar med budgetar på $500,000 eller mindre:
SELECT * FROM employees WHERE department IN ( SELECT name FROM department WHERE budget <= 500000 )
Vi använder en WHERE
-klausul för att specificera att avdelningsnamnet ska finnas i tabellen vi hämtar med den inre frågan.
Låt oss bryta ner denna fråga i två separata för att se hur den fungerar. Först, låt oss hämta namnen på avdelningar med budgetar på $500,000 eller mindre (vår inre fråga):
SELECT name FROM department WHERE budget <= 500000
Nu, med tanke på det erhållna resultatet, låt oss skriva den andra frågan för att hämta information om de anställda från dessa avdelningar:
SELECT * FROM employees WHERE department IN ( 'Marketing', 'Human Resources', 'Finance', 'Customer Service', 'Legal' )
Resultatet av denna fråga kommer att vara samma som den första frågan.
Här är en steg-för-steg-genomgång:
Den inre frågan hämtar
names
på de avdelningar vi behöver;WHERE
-klauselet kontrollerar om dessa avdelningar finns i tabellen från den inre frågan;Vi får det resultat vi vill ha.
Här är den grundläggande syntaxen för en inre fråga:
sql
När du använder nästlade frågor, tänk på dessa viktiga punkter:
Enkelt resultat i underfråga: säkerställ att den nästlade frågan returnerar endast en kolumn. Om den används i en jämförelse, bör den helst returnera ett enda värde. Detta är avgörande för operatorer som
=
,>
,<
,>=
,<=
,<>
;Datatyper: datatypen för den returnerade kolumnen bör matcha kolumnen du jämför den med, för att undvika fel;
Optimering: nästlade frågor kan vara långsamma, särskilt om de körs för varje rad i huvudfrågan;
Använda IN-operatorn: nästlade frågor använder ofta
IN
-operatorn för att kontrollera värden i en delmängd. Du kan också använda jämförelseoperatorer för mer komplexa villkor.
1. Vad är en nästlad fråga i SQL?
2. Vilken SQL-operator används vanligtvis med nästlade frågor för att kontrollera värden i en delmängd?
3. Varför är det viktigt att datatypen för kolumnen som returneras av en nästlad fråga matchar kolumnen den jämförs med?
Tack för dina kommentarer!