Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Lära Nästlade Frågor | Nästlade Subfrågor
Practice
Projects
Quizzes & Challenges
Quizzes
Challenges
/
Intermediär SQL

bookNästlade Frågor

Skoladministrationen är nöjd med våra senaste framgångar och ser fram emot att gå vidare.

När de påbörjar sitt sommarlov får vi möjlighet att utforska nya metoder och förbättra våra SQL-kunskaper.

Vårt fokus kommer att ligga på nästlade frågor, ett centralt begrepp inom SQL.

Note
Definition

Nästlade frågor, eller nästlade subfrågor, är grundläggande komponenter i SQL där en fråga finns inuti en annan fråga. Dessa konstruktioner möjliggör olika operationer såsom datafiltrering, beräkning och hämtning, och kräver ofta integration av subfrågor.

Vi tittar på ett exempel från vårt företagsdatabas. I takt med att företaget växer har vi lagt till en ny department-tabell. Detta förändrar hur vår databas fungerar.

Vi granskar den nya tabellens struktur för att förstå dess roll i databasen:

Den nya tabellen innehåller avdelningar, deras typer och budgetar. Och i tabellen employee finns, som du kanske minns, information om vilken avdelning varje anställd tillhör.

Låt oss titta på 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:

1234567
SELECT * FROM employees WHERE department IN ( SELECT name FROM department WHERE budget <= 500000 )
copy

Vi använder ett WHERE-villkor för att ange att avdelningsnamnet ska finnas i tabellen vi hämtar med den inre frågan.

Låt oss dela upp denna fråga i två separata delar för att se hur den fungerar. Först hämtar vi namnen på avdelningar med budgetar på $500 000 eller mindre (vår inre fråga):

123
SELECT name FROM department WHERE budget <= 500000
copy

Nu, med det erhållna resultatet, skriver vi den andra frågan för att hämta information om de anställda från dessa avdelningar:

12345
SELECT * FROM employees WHERE department IN ( 'Marketing', 'Human Resources', 'Finance', 'Customer Service', 'Legal' )
copy

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:

  1. Den inre frågan hämtar names på de avdelningar vi behöver;

  2. WHERE-satsen kontrollerar om dessa avdelningar finns i tabellen från den inre frågan;

  3. Vi får det resultat vi vill ha.

Här är den grundläggande syntaxen för en inre fråga:

SELECT columns
FROM table_1
WHERE column_name IN (
  SELECT column
  FROM table_2
  other clauses
)

Vid användning av nästlade frågor, tänk på följande viktiga punkter:

  1. Enskilt 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 =, >, <, >=, <=, <>;

  2. Datatyper: datatypen för den returnerade kolumnen ska matcha kolumnen du jämför med, för att undvika fel;

  3. Optimering: nästlade frågor kan vara långsamma, särskilt om de körs för varje rad i huvudfrågan;

  4. Användning av IN-operatorn: nästlade frågor använder ofta operatorn IN för att kontrollera värden i en delmängd. Du kan även 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?

question mark

Vad är en nästlad fråga i SQL?

Select the correct answer

question mark

Vilken SQL-operator används vanligtvis med nästlade frågor för att kontrollera värden i en delmängd?

Select the correct answer

question mark

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?

Select the correct answer

Var allt tydligt?

Hur kan vi förbättra det?

Tack för dina kommentarer!

Avsnitt 2. Kapitel 1

Fråga AI

expand

Fråga AI

ChatGPT

Fråga vad du vill eller prova någon av de föreslagna frågorna för att starta vårt samtal

bookNästlade Frågor

Svep för att visa menyn

Skoladministrationen är nöjd med våra senaste framgångar och ser fram emot att gå vidare.

När de påbörjar sitt sommarlov får vi möjlighet att utforska nya metoder och förbättra våra SQL-kunskaper.

Vårt fokus kommer att ligga på nästlade frågor, ett centralt begrepp inom SQL.

Note
Definition

Nästlade frågor, eller nästlade subfrågor, är grundläggande komponenter i SQL där en fråga finns inuti en annan fråga. Dessa konstruktioner möjliggör olika operationer såsom datafiltrering, beräkning och hämtning, och kräver ofta integration av subfrågor.

Vi tittar på ett exempel från vårt företagsdatabas. I takt med att företaget växer har vi lagt till en ny department-tabell. Detta förändrar hur vår databas fungerar.

Vi granskar den nya tabellens struktur för att förstå dess roll i databasen:

Den nya tabellen innehåller avdelningar, deras typer och budgetar. Och i tabellen employee finns, som du kanske minns, information om vilken avdelning varje anställd tillhör.

Låt oss titta på 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:

1234567
SELECT * FROM employees WHERE department IN ( SELECT name FROM department WHERE budget <= 500000 )
copy

Vi använder ett WHERE-villkor för att ange att avdelningsnamnet ska finnas i tabellen vi hämtar med den inre frågan.

Låt oss dela upp denna fråga i två separata delar för att se hur den fungerar. Först hämtar vi namnen på avdelningar med budgetar på $500 000 eller mindre (vår inre fråga):

123
SELECT name FROM department WHERE budget <= 500000
copy

Nu, med det erhållna resultatet, skriver vi den andra frågan för att hämta information om de anställda från dessa avdelningar:

12345
SELECT * FROM employees WHERE department IN ( 'Marketing', 'Human Resources', 'Finance', 'Customer Service', 'Legal' )
copy

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:

  1. Den inre frågan hämtar names på de avdelningar vi behöver;

  2. WHERE-satsen kontrollerar om dessa avdelningar finns i tabellen från den inre frågan;

  3. Vi får det resultat vi vill ha.

Här är den grundläggande syntaxen för en inre fråga:

SELECT columns
FROM table_1
WHERE column_name IN (
  SELECT column
  FROM table_2
  other clauses
)

Vid användning av nästlade frågor, tänk på följande viktiga punkter:

  1. Enskilt 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 =, >, <, >=, <=, <>;

  2. Datatyper: datatypen för den returnerade kolumnen ska matcha kolumnen du jämför med, för att undvika fel;

  3. Optimering: nästlade frågor kan vara långsamma, särskilt om de körs för varje rad i huvudfrågan;

  4. Användning av IN-operatorn: nästlade frågor använder ofta operatorn IN för att kontrollera värden i en delmängd. Du kan även 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?

question mark

Vad är en nästlad fråga i SQL?

Select the correct answer

question mark

Vilken SQL-operator används vanligtvis med nästlade frågor för att kontrollera värden i en delmängd?

Select the correct answer

question mark

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?

Select the correct answer

Var allt tydligt?

Hur kan vi förbättra det?

Tack för dina kommentarer!

Avsnitt 2. Kapitel 1
some-alt