Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

Le 50 principali domande per l'intervista su SQL Server che devi preparare nel 2022

Nell'era in cui ogni giorno vengono generate enormi quantità di dati, i dati svolgono un ruolo cruciale nel processo decisionale per le operazioni aziendali. Quindi, per gestire i dati abbiamo bisogno di database e questo ci dà la necessità di comprendere i sistemi di gestione dei database. Con vari sistemi di gestione di database, MS SQL Server è uno dei più popolari sistemi di gestione di database relazionali. Questo tipo di DBMS utilizza una struttura che consente agli utenti di identificare e accedere ai dati in relazione a un altro dato nel database. Quindi, conoscere MS SQL Server ti apre le porte per diventare un amministratore di database. Credo che tu sia già a conoscenza di questi fatti e questo ti ha fatto atterrare su questo articolo Domande di intervista su MS SQL Server.

In questo articolo sulle domande di intervista di Microsoft SQL Server, discuterò le principali domande relative a MS SQL Server poste nelle tue interviste. Queste domande vengono raccolte dopo aver consultato persone con competenze eccellenti in questo campo.

Cominciamo!

Q1. Menziona le differenze tra SQL Server e MySQL.

SQL Server MySQL

Sviluppato da Microsoft

Sviluppato da Oracle

Software con licenza

Software open source

Supporta C#, Java C++, PHP, Visual Basic, Perl, Python, Ruby, ecc

Supporta PHP, Perl, Python, Ruby, ecc

Non consente alcun tipo di manipolazione del file di database durante l'esecuzione

Consente la manipolazione dei file di database durante l'esecuzione.

Consente l'annullamento della query a metà del processo

Non consente l'annullamento della query a metà del processo.

Durante il backup dei dati, non blocca il database

Durante il backup dei dati, blocca il database

Occupa una grande quantità di spazio di archiviazione operativo.

Richiede meno spazio di archiviazione operativo.

Disponibile in modalità Express e Personalizzata.

Disponibile in MySQL Community Edition e MySQL Enterprise Edition

Q2. Cosa intendi per SQL Server Agent?

SQL Server Agent è un servizio Windows utilizzato per pianificare ed eseguire processi. Qui, ogni lavoro contiene uno o più passaggi e ogni passaggio contiene un'attività. Pertanto, Server Agent utilizza SQL Server per archiviare le informazioni sui processi ed eseguire un processo in base a una pianificazione.

I componenti principali di SQL Server Agent sono processi, pianificazioni, operatori e avvisi.

Esempio:

Se un'azienda desidera eseguire un backup dei server aziendali ogni venerdì alle 21:00, puoi benissimo automatizzare questa attività per lasciare che la pianificazione avvenga da sola . In uno scenario, il backup rileva un errore, SQL Server Agent registra l'evento e notifica il team corrispondente.

T3. Menziona le diverse modalità di autenticazione in SQL Server.

Prima di indicarti le diverse modalità di autenticazione in SQL Server, lascia che ti dica che la modalità di autenticazione viene utilizzata per autenticare un utente in SQL Server. La modalità di autenticazione viene selezionata durante la configurazione del motore di database. Quindi, se vuoi sapere come configurare Microsoft SQL Server, puoi fare riferimento al mio articolo.

Le diverse modalità di autenticazione offerte da SQL SERVER sono le seguenti:

  • Modalità di autenticazione di Windows: Questa modalità viene utilizzata per connettere il server tramite un account Windows. Qui, il server prende il nome utente e la password dei computer per scopi di autenticazione. Inoltre, la modalità di autenticazione del server SQL è disabilitata in questa modalità.
  • Modalità mista: La modalità mista viene usata per connettersi a un'istanza di SQL Server utilizzando l'autenticazione di SQL Server o l'autenticazione di Windows. In questa modalità, l'utente imposta un nome utente e una password per il database.

Q4. Indica le differenze tra le tabelle temporanee locali e globali.

Tabella temporanea locale Tabella temporanea globale

Queste tabelle esistono solo per la durata della connessione o per la durata di tale istruzione.

Queste tabelle esistono permanentemente nel database e solo le righe vengono eliminate quando la connessione viene chiusa.

Sintassi: CREA TABELLA #

Sintassi: CREA TABELLA ##

Q5. Come puoi verificare la versione di SQL Server?

Per verificare la versione di SQL Server, puoi utilizzare il seguente comando:

SELECT @@version

@@VERSION fornisce l'output come una stringa nvarchar.

Q6. Che cos'è la modalità utente singolo e quali sono i passaggi da seguire per avviare SQL Server in modalità utente singolo?

Può capitare spesso di voler avviare un'istanza di SQL Server in modalità utente singolo. Puoi farlo sia quando desideri recuperare i dati da altri sistemi di database sia quando desideri modificare le configurazioni del server.

Quando si avvia SQL Server in modalità utente singolo, qualsiasi membro del gruppo Administrators locale del computer viene connesso all'istanza di SQL Server come sysadmin.

I seguenti eventi si verificano all'avvio del database in modalità utente singolo:

  • Un singolo utente si connette al server.
  • Il CHECKPOINT processo non viene eseguito poiché viene eseguito per impostazione predefinita all'avvio.

Si noti inoltre che è necessario arrestare il servizio SQL Server Agent prima di connettersi a un'istanza di SQL Server in modalità utente singolo.

  • Per avviare SQL Server in modalità utente singolo, utilizzare il comando: sqlcmd –m
  • Per connettersi tramite l'editor di query in Management Studio, utilizzare: -m"Microsoft SQL Server Management Studio - Query".

Q7. Che cos'è SQL Server Profiler?

Microsoft SQL Server Profiler è un'interfaccia utilizzata per creare e gestire le tracce. Analizza e riproduce anche i risultati della traccia. Qui, gli eventi vengono salvati in un file di traccia che viene successivamente analizzato o utilizzato per riprodurre una serie specifica di passaggi durante il debug di un problema.

È possibile utilizzare SQL Server Profiler per attività quali:

  1. Trovare la causa principale del problema
  2. Monitoraggio delle prestazioni di SQL Server per gestire i carichi di lavoro.
  3. Diagnostica delle query lente
  4. Cattura di una serie di istruzioni SQL che causano problemi, per replicare ulteriormente il problema sul server di test, mentre si esegue il debug del problema.
  5. Aiuta anche a correlare i contatori delle prestazioni per eseguire facilmente il debug dei problemi.

D8. Qual è la porta TCP/IP su cui viene eseguito SQL Server?

La porta TCP/IP su cui viene eseguito SQL Server è 1433.

Q9. Cosa sono le sottoquery in SQL Server? Spiega le sue proprietà.

Una sottoquery è una query all'interno di un'altra query in cui viene definita una query per recuperare dati o informazioni dal database. In una sottoquery, la query esterna viene chiamata come query principale mentre la query interna viene chiamata subquery. Le sottoquery vengono sempre eseguite per prime e il risultato della sottoquery viene passato alla query principale. Può essere nidificato all'interno di una SELECT, UPDATE o qualsiasi altra query. Una sottoquery può anche utilizzare qualsiasi operatore di confronto come>,

Le proprietà delle sottoquery sono le seguenti:

  • Deve essere racchiuso tra parentesi in quanto deve essere eseguito prima della query principale
  • Può essere inclusa più di una query.
  • Una sottoquery non dovrebbe avere la clausola ORDER BY ma può includere WHERE, GROUP BY e HAVING CLAUSE
  • La sottoquery deve trovarsi sul lato destro dell'operatore di confronto della query principale
  • Una sottoquery deve includere la clausola SELECT e una clausola FROM.

Q10. Come si avvia la modalità utente singolo in cluster installazioni?

Nell'installazione in cluster, SQL Server utilizza la connessione disponibile DLL e quindi blocca qualsiasi altra connessione al server.

In questo stato, se si tenta di portare in linea le risorse di SQL Server Agent, è possibile che venga eseguito il failover delle risorse SQL su un nodo diverso poiché potrebbe essere configurato in un gruppo. Quindi, per avviare una modalità utente singola nell'installazione in cluster, puoi seguire i passaggi seguenti:

  1. Vai a proprietà avanzate e rimuovi il parametro di avvio -m.
  2. Ora, metti offline la risorsa di SQL Server.
  3. Emetti il ​​seguente comando dal prompt dei comandi e assicurati di trovarti nel nodo proprietario corrente del gruppo:
    net start MSSQLSERVER /m.
  4. Successivamente, devi verificare dall'amministratore del cluster o eseguire il failover della console di gestione del cluster che la risorsa di SQL Server sia ancora offline o meno.
  5. Quindi, connettiti a SQL Server utilizzando il comando seguente ed esegui l'operazione richiesta:SQLCMD -E -S<servername>.
  6. Una volta completata un'operazione, devi chiudere il prompt dei comandi e quindi riportare l'SQL e altre risorse online tramite l'amministratore del cluster.

Q11. Cosa intendi per replica in SQL Server? Menziona i diversi tipi di replica in SQL Server.

La replica in Microsoft SQL Server è un processo per sincronizzare i dati su più server. Questa operazione viene generalmente eseguita da un set di repliche e questi set forniscono più copie di dati con ridondanza e disponibilità elevata su server diversi.

Non solo questo, ma la replica fornisce un meccanismo per il ripristino dagli errori. Rimuove anche le dipendenze da un singolo server per proteggere la perdita di dati da un singolo server.

Di seguito sono riportati tre tipi di repliche in SQL Server:

  1. Unire replica: Questa replica raggruppa i dati da varie origini in un unico database centralizzato e viene utilizzata dal server all'ambiente client.
  2. Replica transazionale: Questa replica è un processo di distribuzione dei dati dall'editore all'abbonato e viene utilizzata in un ambiente da server a server.
  3. Replica snapshot: Questa replica distribuisce i dati esattamente come appaiono in un momento specifico e viene utilizzata per replicare i dati, che cambiano di rado.

Q12. Quali sono le differenze tra MS SQL Server e Oracle?

MS SQL Server Oracle

Fornisce una sintassi semplice e facile.

Consiste in una sintassi complessa e relativamente più efficiente.

Utilizza transazioni SQL o T-SQL.

Utilizza PL/SQL

Non supporta l'ottimizzazione delle query.

Utilizza l'ottimizzazione delle query a stella.

I rollback non sono consentiti nel processo di transazione.

I rollback sono consentiti durante il processo di transazione.

Consente backup incrementali, parziali e completi

Consente backup incrementali, completi, a livello di file e differenziali.

Non supporta il clustering.

Offre supporto per la configurazione in cluster.

Le istruzioni come INSERT, UPDATE, DELETE vengono eseguite in serie.

Le istruzioni come INSERT, UPDATE, DELETE, MERGE vengono eseguite parallelamente.

I lavori sono pianificati tramite SQL Server Agent

I lavori sono pianificati tramite Oracle scheduler o OEM

Q13. Cosa intendi per blocchi INTENT?

Microsoft SQL Server utilizza una gerarchia di blocchi ogni volta che i dati vengono letti o qualcosa viene modificato nei dati. Ogni volta che viene letta una riga, SQL Server acquisisce un blocco condiviso. Allo stesso modo, non appena cambiamo una riga, SQL Server acquisisce un blocco esclusivo. Questi blocchi sono incompatibili tra loro. Pertanto, i blocchi INTENT vengono utilizzati per indicare a un livello superiore quali blocchi vengono applicati all'interno di una gerarchia di blocchi. Esistono principalmente tre tipi di blocchi INTENT:

  1. Blocco condiviso intento(IS): Questo blocco viene utilizzato quando hai un blocco condiviso a livello di riga.
  2. Blocco aggiornamento intenti (IU): Il blocco dell'aggiornamento dell'intento viene utilizzato quando hai un blocco dell'aggiornamento a livello di riga.
  3. Blocco esclusivo Intext(IX): Questo blocco viene utilizzato quando hai un blocco esclusivo a livello di riga.

Q14. Quali sono i passaggi da seguire per nascondere le istanze di SQL Server?

I passaggi da seguire per nascondere le istanze di SQL Server sono i seguenti:

  • Apri Gestione configurazione SQL Server ed espandi la Configurazione di rete di SQL Server
  • Quindi vai su Protocolli e scegli l'istanza di SQL Server .
  • In seguito, fai clic con il pulsante destro del mouse sull'istanza e seleziona le Proprietà

  • Successivamente, nella casella Nascondi istanza , vai alla scheda Flag e seleziona .
  • Infine, fai clic su OK e chiudi la finestra di dialogo.

Q15. Cosa intendi per servizi di qualità dei dati in SQL Server?

I servizi di qualità dei dati in SQL Server sono un prodotto di qualità dei dati basato sulla conoscenza. SQL Server Data Quality Services (DQS) consente all'utente di creare una base di conoscenza e di utilizzarla successivamente per eseguire attività quali correzione, deduplicazione, arricchimento e standardizzazione dei dati.

Oltre a questo, DQS fornisce anche la profilazione e ti consente di eseguire la pulizia dei dati con l'aiuto di servizi di dati basati su cloud.

DQS è costituito da due componenti:

  • Server della qualità dei dati: È una funzionalità dell'istanza di SQL Server composta da tre cataloghi di SQL Server con funzionalità di qualità dei dati e archiviazione
  • Cliente per la qualità dei dati: È una funzionalità di SQL Server che gli utenti possono utilizzare per eseguire analisi della qualità dei dati assistite da computer e gestire la qualità dei dati in modo interattivo.

Q16. Spiega le tabelle magiche nel server SQL

Le tabelle magiche sono tabelle create automaticamente in SQL Server utilizzate per archiviare internamente i valori inseriti e aggiornati per operazioni DML come (SELECT, DELETE, INSERT, UPDATE, ecc.).

Q17. Cosa capisci da Modifica acquisizione dati ?

Change Data Capture o più comunemente noto come CDC viene utilizzato per registrare le attività INSERT, UPDATE, DELETE applicate alle tabelle. Quindi, come suggerisce il nome, Change Data Capture viene utilizzato per acquisire i dati che sono stati modificati di recente. Le informazioni sulla colonna e i metadati necessari per applicare le modifiche all'ambiente di destinazione vengono acquisiti per le righe modificate e infine archiviati nelle tabelle delle modifiche. Queste tabelle delle modifiche sono l'immagine speculare della struttura della colonna originale.

Q18. Cosa intendi per trigger e ne menzioni i diversi tipi?

I trigger vengono utilizzati per eseguire batch di codice SQL ogni volta che i comandi INSERT, DELETE o UPDATE vengono eseguiti su una tabella. Quindi, in pratica, i trigger vengono eseguiti automaticamente ogni volta che i dati vengono modificati in base alle operazioni di manipolazione dei dati.

I diversi tipi di trigger sono i seguenti:

  1. INSERIRE
  2. AGGIORNAMENTO
  3. ELIMINA
  4. INVECE DI

Q19. Cosa intendi per procedura memorizzata ricorsiva?

Una procedura memorizzata ricorsiva è un metodo di risoluzione dei problemi attraverso il quale puoi arrivare alla soluzione ancora e ancora.

Q20. Spiega Log Shipping e menziona i suoi vantaggi.

Il processo di automazione del backup per ripristinare i database da un server standalone a un altro server standalone standalone è noto come Log Shipping. Puoi anche considerare il log shipping come una delle soluzioni di ripristino di emergenza, in quanto garantisce che anche in caso di guasto di un server, il server di standby avrà gli stessi dati del server stesso.

I vantaggi di Log Shipping sono i seguenti:

  • Richiede poca manutenzione ed è facile da configurare
  • Il database secondario creato viene utilizzato per scopi di sola lettura.
  • Puoi creare più server di standby secondari
  • Consente un ritardo specificato dall'utente per il tempo che intercorre tra il backup del server primario del registro del database primario quando i server secondari ripristinano (applicano) il backup del registro.

Q21. Cosa sono i flag di traccia e menzionare alcuni flag di traccia comuni utilizzati con SQL Server?

Questi flag sono usati per alterare il comportamento del server o per impostare le caratteristiche del server. Alcuni flag di traccia comuni utilizzati con SQL Server sono i seguenti

  • 1204, 1205, 1222 – Questi flag vengono utilizzati per le informazioni sul deadlock.
  • 174 – Questo flag di traccia aumenta il numero di bucket della cache del piano di Motore di database di SQL ServerSQL Server Database Engine da 40.009 a 160.001 su sistemi a 64 bit.
  • 1118 – Impone allocazioni di extent uniformi invece di allocazioni di pagine miste – (SQL 2005 e 2008) Per ridurre la contesa TempDB.
  • 652 – Questo flag di traccia disabilita le scansioni di precaricamento delle pagine.
  • 2566 – Utilizzato per eseguire il comando DBCC CHECKDB senza il controllo della purezza dei dati, a meno che non sia specificata l'opzione DATA_PURITY.

Q22. Menziona le differenze tra SUBSTR e CHARINDEX in SQL Server.

SUBSTR CHARINDEX

Utilizzato per restituire una parte specifica della stringa in una determinata stringa

Utilizzato per restituire la posizione di un carattere in una determinata stringa specificata

Esempio:

SUBSTRING('Edureka',1,4)

Risultato:

Edur

Esempio:

CHARINDEX('r','Edureka',1)

Risultato:

4

Q23. Cosa intendi per Analysis Services in SQL Server?

Analysis Services in Microsoft SQL Server è un motore di dati analitici utilizzato nell'analisi aziendale e nel supporto decisionale. Questo servizio fornisce modelli semantici di livello aziendale per applicazioni client e report come Power BI, Microsoft Excel e altri strumenti di visualizzazione.

Analysis Services è disponibile in piattaforme come :

  1. Servizi di analisi di Azure
  2. Power BI Premium
  3. Servizi di analisi di SQL Server

Q24. Cosa intendi per Mirroring e menzioni i vantaggi del Mirroring?

Il mirroring in SQL Server è progettato per mantenere un server hot standby, coerente con il server primario in termini di transazione. Inoltre, i record del registro delle transazioni vengono inviati dal server principale al server secondario.

Di seguito sono riportati i vantaggi del mirroring:

  1. Consiste in un meccanismo di failover automatico.
  2. Più efficiente di Log Shipping ed è più robusto.
  3. Il server primario viene sincronizzato con il server secondario in tempo reale

Q25. Quando pensi che uno sviluppatore dovrebbe utilizzare i cursori basati su SQL Server?

I cursori basati su SQL Server vengono utilizzati quando si desidera lavorare su un record in qualsiasi momento, invece di prendere tutti i dati da una tabella in blocco. Tuttavia, non è preferibile utilizzare i cursori quando sono presenti grandi volumi di dati poiché influiscono sulle prestazioni. In uno scenario in cui non è possibile evitare i cursori, provare a ridurre il numero di record da elaborare utilizzando una tabella temporanea e quindi creare eventualmente il cursore da questa.

Q26. Quale ruolo ha la progettazione del database nelle prestazioni di un'applicazione basata su SQL Server?

Il design fisico e logico gioca un ruolo importante nelle prestazioni delle applicazioni basate su SQL Server. È necessario garantire che i dati corretti vengano acquisiti in tabelle appropriate, che gli elementi di dati abbiano relazioni adeguate tra loro e la ridondanza dei dati sia ridotta. Suggerirei anche che mentre stai progettando un database, assicurati che sia un processo iterativo per raggiungere tutti gli obiettivi di sistema richiesti e che sia sotto costante osservazione. Una volta impostata la progettazione del database, è molto difficile modificare la progettazione in base alle esigenze. Puoi solo aggiungere nuove relazioni ed elementi di dati.

Q27. Cosa intendi per funzione definita dall'utente in SQL Server e spieghi i passaggi per creare ed eseguire una funzione definita dall'utente in SQL Server?

Una funzione definita dall'utente è una funzione scritta secondo le esigenze dell'utente implementando la logica. In questo tipo di funzioni l'utente non si limita a funzioni predefinite e semplifica il codice complesso di funzioni predefinite scrivendo un codice semplice. Questa funzione restituisce un valore scalare o una tabella.

Per creare una funzione definita dall'utente, fare riferimento al seguente esempio:

CREATE FUNCTION samplefunc(@num INT)
RETURNS TABLE
AS
RETURN SELECT * FROM customers WHERE CustId=@num

Per eseguire la funzione sopra creata, fare riferimento al seguente comando:

SELECT * FROM samplefunc(10)

Q28. Come puoi assicurarti che il database e l'applicazione basata su SQL Server funzionino bene?

Uno sviluppatore deve controllare il tipo di informazioni memorizzate, il volume di dati e i dati a cui si accederà.

In uno scenario, in cui stai aggiornando un sistema esistente, dovresti analizzare i dati attuali, si verificano i volumi di dati esistenti e controllare il metodo attraverso il quale si accede ai dati, per aiutarti comprendere le aree problematiche per la progettazione.

In uno scenario, in cui stai utilizzando un nuovo sistema, devi conservare le informazioni su quali dati verranno acquisiti, quali sono i componenti dei dati e la relazione tra i dati.

Q29. Cosa sono le relazioni e menziona i diversi tipi di relazioni nel DBMS

Una relazione in DBMS è lo scenario in cui due entità sono correlate tra loro. In tale scenario, la tabella composta da chiave esterna fa riferimento a quella di una chiave primaria dell'altra tabella.

I diversi tipi di relazioni in DBMS sono i seguenti:

  • Relazione uno-a-uno – Utilizzato quando una singola riga nella Tabella A è correlata a una singola riga nella Tabella B.
  • Relazione uno-a-molti – Utilizzato quando una singola riga nella tabella A è correlata a molte righe nella tabella B.
  • Relazione molti-a-molti – Usato quando molte righe nella tabella A possono essere correlate a molte righe nella tabella B.
  • Relazione autoreferenziale – Utilizzato quando un record nella tabella A è correlato a un record nella stessa tabella.

Q30. Cosa sono i join in SQL e quali sono i diversi tipi di join?

Una clausola JOIN viene utilizzata per combinare righe di due o più tabelle, in base a una colonna correlata tra di loro. Viene utilizzato per unire due tabelle o recuperare dati da lì. Ci sono 4 join in SQL, vale a dire:

  • Unione interna
  • Partecipa a destra
  • Partecipa a sinistra
  • Partecipa completa

Q31. A cosa serve il comando DBCC CHECKDB?

Il comando DBCC CHECKDB viene utilizzato per verificare l'integrità fisica e logica di tutti gli oggetti nel database menzionato. Per farlo, esegue le seguenti operazioni:

  • Esegue DBCC CHECKALLOC sulla banca dati menzionata.
  • Su ogni tabella e vista nel database, il DBCC CHECKTABLE il comando viene eseguito.
  • Esegue DBCC CHECKCATALOG nel database.
  • Quindi ha convalidato il contenuto di ogni vista indicizzata nel database menzionato.
  • Convalida anche la coerenza a livello di collegamento tra le directory del file system e i metadati delle tabelle durante la memorizzazione dei dati varbinary(max) nel file system utilizzando FILESTREAM.
  • Infine, convalida i dati di Service Broker nel database.

Quindi, devi solo eseguire il comando DBCC CHECKDB e automaticamente i comandi DBCC CHECKALLOC, DBCC CHECKTABLE o DBCC CHECKCATALOG vengono eseguiti.

Si noti inoltre che DBCC è supportato nei database che contengono tabelle ottimizzate per la memoria ma non fornisce opzioni di riparazione. Ciò implica che è necessario eseguire regolarmente il backup dei database e testare tali backup.

Q32. Cosa intendi per vincolo CHECK in SQL Server?

Il vincolo CHECK in SQL Server viene utilizzato per limitare i valori o il tipo di dati archiviati in una colonna. Dopo aver applicato il vincolo CHECK su una singola colonna, puoi andare avanti e applicare valori specifici per quella particolare colonna.

Esempio:

CREATE TABLE Customer (&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;Cust_ID int NOT NULL,&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;FirstName varchar(255),&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;Age int,&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;City varchar(255),&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;CONSTRAINT CHK_Customer CHECK (Age>20 AND City= 'Hyderabad')&nbsp;&nbsp;
);&nbsp;&nbsp;

Q33. Cosa fare capisci COALESCE in SQL Server?

Questa funzione viene utilizzata per restituire la prima espressione non nulla all'interno degli argomenti. Il comando COALESCE viene utilizzato per restituire un valore non nullo da più di una singola colonna negli argomenti.

Esempio:

SELECT COALESCE(CustID, CustName, Amount) from Customers;

Q34. Spiega l'utilizzo della funzione FLOOR in SQL Server.

La funzione FLOOR viene utilizzata per arrotondare per eccesso un valore non intero al valore intero minimo precedente. Questa funzione restituisce un valore univoco dopo aver arrotondato le cifre.

Sintassi:

FLOOR(expression)

Esempio:

FLOOR(7.3)

Q35. Qual ​​è il comando utilizzato per controllare i blocchi in Microsoft SQL Server?

Per controllare i blocchi nel database, puoi utilizzare la procedura memorizzata integrata sp_lock.

Sintassi

sp_lock [ [ @spid1 = ] 'session ID1' ] [ , [@spid2 = ] 'session ID2' ]
[ ; ]

Esempio:

Per elencare tutti i blocchi attualmente mantenuti in un'istanza del Motore di database, utilizzare il comando seguente:

USE SampleDB;  
GO  
EXEC sp_lock;  
GO  

Q36. Indica i 3 modi per ottenere un conteggio del numero di record in una tabella.

Di seguito sono riportati tre modi per contare il numero di record nella tabella:

SELECT * FROM TableName;
SELECT COUNT(*) FROM TableName;
SELECT rows FROM indexes WHERE id = OBJECT_ID(TableName) AND indexid< 2;

Q37. Qual è l'utilizzo della funzione SEGNO?

Questa funzione viene utilizzata per determinare se il numero indicato è zero, positivo e negativo. Quindi, restituirà 0, +1, -1.

Sintassi:

SIGN(number)

Esempio:

SIGN (0)  returns 0
SIGN (21)  returns 1
SIGN (-21)  returns -1

Q38. Scrivere una query SQL per trovare il primo giorno della settimana del mese?

Per trovare il primo giorno della settimana del mese, puoi scrivere una query come segue:

SELECT DATENAME(dw, DATEADD(dd, – DATEPART(dd, GETDATE()) + 1, GETDATE())) AS FirstDay;

Q39. Menziona il comando utilizzato per rinominare il database.

Per rinominare un database, devi usare il comando sp_renamedb nel modo seguente:

sp_renamedb 'OldDatabaseName', 'NewDatabaseName';

Q40. Scrivi una query per trovare il 5° importo più alto pagato dalla tabella Clienti.

Per trovare il 5° importo più alto pagato dalla tabella dei clienti, puoi scrivere una query come di seguito:

SELECT TOP 1 amount FROM (SELECT DISTINCT TOP 5 amount FROM customers ORDER BY amount DESC) ORDER BY amount;

Q41. How can we delete a table in SQL Server?

To delete a table in SQL Server, use the Delete command.

Sintassi:

DELETE TableName

Esempio:

DELETE Customers;

Q42. What is the purpose of UPDATE STATISTICS and SCOPE_IDENTITY() function ?

  • UPDATE _STATISTICS is used to update the information used by indexes such as the distribution of key values for one or more statistic groups in the mentioned indexed view or table.
  • SCOPE_IDENTITY is used to create identity value for tables in the current execution scope.

Q43. What do you understand by PHYSICAL_ONLY option in DBCC CHECKDB?

  • The PHYSICAL_ONLY option is used to limit check to the integrity of the physical structure of the record headers, page, and also the allocation consistency of the database.
  • The PHYSICAL_ONLY check is used to provide a small overhead check of the physical consistency of the database.
  • Also, the PHYSICAL_ONLY option causes a shorter run-time for DBCC CHECKDB on large databases. So, it is generally recommended for frequent use on production systems.

Q44. Can you explain how long are locks retained within the REPEATABLE_READ and SERIALIZABLE isolation levels, during a read operation with row-level locking?

With REPEATABLE_READ and SERIALIZABLE isolation levels, locks are held during the transaction. But, if you consider READ_COMMITTED, then locks are held for isolation level.

Q45. Mention the differences between HAVING and WHERE clause.

HAVING WHERE
Used only with SELECT statement Used in a GROUP BY clause
Used with the GROUP BY function in a query Applied to each row before they are a part of the GROUP BY function in a query

Nota: Whenever GROUP BY is not used, HAVING behaves like a WHERE clause.

Q46. What do you understand by integration services in SQL Server?

Integration services is a platform offered by Microsoft to build enterprise-level data transformation solutions and integration. These services solve complex business problems by loading data warehouses, perform data wrangling, copy or download files, and manage SQL Server objects.

Also, integration services can extract and transform data from a wide variety of sources such as relational data sources, XML data files, load the data into more than a single database. So, basically, you can use the integration services to create solutions without coding, code complex tasks, program the extensive integration object model to create packages.

The integration services include good set of built-in tasks and transformations, graphical tools used for building packages and also contain the Catalog database to store, run and manage packages.

Q47. What do you understand by Hotfixes and Patches in SQL Server?

Hotfixes are single, cumulative software packages applied to live systems. This includes one or more files used to address a problem in a software product. Patches are a programs installed on the machines to rectify the problem occurred in the system and ensured the security of the system. So, basically hotfixes are a kind of patch offered by Microsoft SQL Server to address specific issues.

Q48. Can you name a few encryption mechanisms in SQL server?

These are few encryption mechanisms in SQL Server to encrypt data in the database:

  1. Transparent Data Encryption
  2. Symmetric Keys
  3. Asymmetric Keys
  4. Transact SQL functions
  5. Certificates

Q49. What are the options which must be set to allow the usage of optimistic models?

The READ_COMMITED_SNAPSHOT option and the ALLOW_SNAPSHOT_ISOLATION option must be set to allow the usage of optimistic models.

  • The READ_COMMITTED_SNAPSHOT option is used for the read committed optimistic model.
  • ALLOW_SNAPSHOT_ISOLATION option is used for the snapshot isolation level.

Q50. What are the common performance issues in SQL Server?

The common performance issues in SQL Server are as follows:

  • Fragmentation
  • Input/Output bottlenecks
  • Blocking Queues
  • Deadlocks
  • Missing and unused indexes

So this brings us to the end of the SQL Server Interview Questions article. I hope this set of SQL Server Interview Questions will help you ace your job interview. All the best for your interview!

Check out this Formazione per la certificazione DBA MySQL di Edureka, una società di formazione online affidabile con una rete di di oltre 250.000 studenti soddisfatti sparsi in tutto il mondo. Questo corso ti insegna i concetti fondamentali e gli strumenti e le tecniche avanzati per gestire i dati e amministrare il database MySQL. Include l'apprendimento pratico su concetti come MySQL Workbench, MySQL Server, Data Modeling, MySQL Connector, Database Design, MySQL Command line, MySQL Functions, ecc. Alla fine della formazione sarai in grado di creare e amministrare il tuo database MySQL e gestire i dati.

Hai una domanda per noi? Please mention it in the comments section of this “SQL Server Interview Questions” article and we will get back to you as soon as possible.