Interviewspørgsmål til SQL-udviklere: Almindelige SQL-interview-spørgsmål og svar- del 4

Forklar konceptet med at skabe function og procedure i SQL og fordelene ved at bruge dem.

Svar: Function og procedure i SQL hedder kodeblokke, der kan kaldes fra andre forespørgsler eller applikationer.

  • Function: Returnerer en værdi og bruges ofte til beregninger og returnering af resultater.
  • Procedure: Returnerer ikke en værdi og bruges til at udføre databehandling eller lagringsopgaver.

Fordelene ved at bruge funktioner og procedurer omfatter:

  • Reducerer kodeduplikering, hvilket gør det nemmere at vedligeholde og administrere kode.
  • Øger genanvendeligheden, så koden kan genbruges flere steder.
  • Forbedring af ydeevnen, da funktioner og procedurer ofte kompileres én gang og genbruges flere gange.

 

Sådan bruger du RECURSIVE forespørgsler og COMMON TABLE EXPRESSION(CTE) i SQL.

Svar: RECURSIVE forespørgsler og COMMON TABLE EXPRESSION(CTE) bruges til at håndtere rekursive forespørgsler og genbruge en del af en forespørgsel i SQL.

  • RECURSIVE: Giver mulighed for at udføre rekursive forespørgsler i databasen.
  • CTE: Fungerer som et midlertidigt resultatsæt, der deler en forespørgsel op i mindre, mere håndterbare dele.
WITH RECURSIVE RecursiveCTE(ID, ParentID, Level) AS( 
  SELECT ID, ParentID, 0 AS Level FROM Categories WHERE ParentID IS NULL  
  UNION ALL  
  SELECT C.ID, C.ParentID, Level + 1 FROM Categories C  
  INNER JOIN RecursiveCTE RC ON C.ParentID = RC.ID  
)  
SELECT * FROM RecursiveCTE;  

 

Sådan håndteres dublerede data og ugyldige datasager i SQ

Svar: For at håndtere duplikerede og ugyldige data i SQL kan vi bruge SQL-sætninger som DISTINCT, GROUP BY, HAVING og UNIQUE begrænsninger for at sikre dataentydighed. Derudover kan vi bruge UPDATE eller DELETE erklæringer til at eliminere duplikerede eller ugyldige poster.

 

Her er oversættelsen af ​​de specielle datatyper i SQL Server

Các kiểu dữ liệu đặc biệt như XML, GEOGRAPHY, og GEOMETRY via SQL Server på phức tạp. Dưới đây là mô tả về từng kiểu dữ liệu này:

XML:

  • XML-datatypen i SQL Server tillader lagring og arbejde med data i Extensible Markup Language-format.
  • XML-data kan indeholde rige strukturer, hvilket muliggør lagring af velorganiseret og fleksibel information.
  • SQL Server giver funktioner og metoder til at manipulere XML-data, hvilket gør det muligt at forespørge, oprette og transformere XML-data.

GEOGRAPHY Og GEOMETRY:

  • Datatyperne GEOGRAPHY og GEOMETRY i SQL Server bruges til at lagre geografisk og geometrisk information.
  • GEOGRAPHY bruges til at repræsentere geografiske objekter såsom punkter, linjer, områder og polygoner på jordens overflade.
  • GEOMETRY bruges til at repræsentere geometriske objekter såsom punkter, linjer, områder og polygoner i et fladt rum.

Begge datatyper understøtter specielle operationer og funktioner til forespørgsel og analyse af geografiske og geometriske data.

 

Forklar funktioner og funktioner til håndtering af dato- og tidsdata i SQL

Funktioner og funktioner til behandling af dato- og tidsdata i SQL bruges til at manipulere og udføre opgaver relateret til datoer og klokkeslæt i databasen. Her er en detaljeret beskrivelse af nogle almindelige funktioner og funktioner:

DATEPART():Denne funktion bruges til at udtrække en specifik komponent(f.eks. dag, måned, år, time, minut, sekund) fra en dato- eller tidsværdi.

SELECT DATEPART(YEAR, '2023-07-19'); -- Result: 2023

DATEDIFF(): Denne funktion beregner tidsforskellen mellem to dato- eller tidsværdier.

SELECT DATEDIFF(DAY, '2023-07-01', '2023-07-19'); -- Result: 18(number of days between two dates)

DATEADD(): Denne funktion tilføjer et bestemt antal dage, måneder, år eller klokkeslæt til en dato- eller tidsværdi.

SELECT DATEADD(DAY, 7, '2023-07-19'); -- Result: '2023-07-26'(adding 7 days)

GETDATE(): Denne funktion returnerer den aktuelle dato og klokkeslæt for systemet.

SELECT GETDATE(); -- Result: '2023-07-19 12:34:56.789'

CONVERT(): Denne funktion bruges til at konvertere dato- eller tidsværdier fra et format til et andet.

SELECT CONVERT(VARCHAR, '2023-07-19', 103); -- Result: '19/07/2023'

FORMAT(): Denne funktion bruges til at formatere dato- eller tidsværdier i overensstemmelse med et foruddefineret mønster.

SELECT FORMAT('2023-07-19', 'dd/MM/yyyy'); -- Result: '19/07/2023'