Procedura: eseguire il debug di oggetti database CLR
Si applica a:SQL Server
SQL Server fornisce il supporto per il debug di oggetti Transact-SQL e CLR (Common Language Runtime) nel database. Gli aspetti principali del debug in SQL Server sono la facilità di installazione e utilizzo e l'integrazione del debugger di SQL Server con il debugger di Microsoft Visual Studio. Inoltre, il debug funziona tra linguaggi diversi. Gli utenti possono passare senza problemi agli oggetti CLR da Transact-SQL e viceversa.
Il debugger Transact-SQL in SQL Server Management Studio non può essere usato per eseguire il debug di oggetti di database gestiti, ma è possibile eseguire il debug degli oggetti usando i debugger in Visual Studio. Il debug di oggetti di database gestiti in Visual Studio supporta tutte le funzionalità di debug comuni, ad esempio eseguire istruzioni e eseguire istruzioni all'interno delle routine eseguite nel server. Tramite i debugger è possibile impostare punti di interruzione, controllare lo stack di chiamate, controllare le variabili e modificarne i valori durante il debug.
Autorizzazioni e restrizioni di debug
Il debug è un’operazione con privilegi elevati, pertanto, solo i membri del ruolo predefinito del server amministratore di sistema possono eseguire il debug in SQL Server.
Durante il debug vengono applicate le restrizioni seguenti:
Il debug di routine CLR è limitato a un'istanza di debugger alla volta. Questa limitazione si applica perché l'esecuzione di tutto il codice CLR si blocca quando viene raggiunto un punto di interruzione e l'esecuzione non continua fino a quando il debugger non avanza dal punto di interruzione. Tuttavia, è possibile continuare il debug di Transact-SQL in altre connessioni. Anche se il debug Transact-SQL non blocca altre esecuzioni sul server, può causare l'attesa di altre connessioni mantenendo un blocco.
Non è possibile eseguire il debug delle connessioni esistenti, ma solo le nuove connessioni, perché SQL Server richiede informazioni sull'ambiente client e debugger prima di poter effettuare la connessione.
È quindi consigliabile eseguire il debug di Transact-SQL e del codice CLR in un server di test e non in un server di produzione.
Panoramica
Il debug in SQL Server si basa su un modello per connessione. Un debugger può rilevare ed eseguire il debug delle attività solo sulla connessione client a cui si connette. Poiché la funzionalità del debugger non è limitata dal tipo di connessione, è possibile eseguire il debug di entrambe le connessioni TDS (Tabular Data Stream) e HTTP. SQL Server, tuttavia, non consente il debug delle connessioni esistenti. Il debug supporta tutte le caratteristiche di debug comuni all'interno di routine in esecuzione nel server. L'interazione tra un debugger e SQL Server viene effettuata tramite Distributed Component Object Model (COM).
Per altre informazioni e scenari sul debug di stored procedure gestite, funzioni, trigger, tipi definiti dall'utente e aggregazioni, vedi Debug del database di integrazione CLR di SQL Server nella documentazione di Visual Studio.
È necessario abilitare il protocollo di rete TCP/IP nell'istanza di SQL Server per usare Visual Studio per lo sviluppo e il debug remoti. Per altre informazioni sull'abilitazione del protocollo TCP/IP nel server, vedi Configurare i protocolli client.
Passaggi di debug
Usare la procedura seguente per eseguire il debug di un oggetto database CLR in Microsoft Visual Studio:
Apri Microsoft Visual Studio e seleziona Crea un nuovo progetto SQL Server. Puoi usare l'istanza di SQL Local DB fornita con Visual Studio.
Crea un nuovo tipo CLR SQL (C#):
- Fai clic con il pulsante destro del mouse sul progetto in Esplora soluzioni e seleziona Aggiungi, Nuovo articolo....
- Nella finestra Aggiungi nuovo articolo seleziona Stored procedure SQL CLR C#, Funzione definita dall'utente SQL CLR C#, Tipo definito dall’utente SQL CLR C#, Grilletto SQL CLR C#, Aggregazione SQL CLR C# o Classe.
- Specifica un nome per il file di origine del nuovo tipo e quindi seleziona Aggiungi.
Aggiungere il codice per il nuovo tipo nell'editor di testo. Per un codice di esempio relativo a un esempio di stored procedure, vedei la sezione Esempi più avanti in questo articolo.
Aggiungi uno script di test per il tipo:
- In Esplora soluzioni fai clic con il pulsante destro del mouse sul nodo progetto e seleziona Aggiungi, Script....
- Nella finestra Aggiungi nuovo articolo seleziona Script (Non in compilazione) e specifica un nome, ad esempio
Test.sql
. Seleziona il pulsante Aggiungi. - In Esplora soluzioni fai doppio clic sul
Test.sql
nodo per aprire il file di origine dello script di test predefinito. - Aggiungi nell'editor di testo uno script di test (che richiama il codice di cui eseguire il debug). Vedi l'esempio nella sezione successiva per uno script campione.
Inserire uno o più punti di interruzione nel codice sorgente. Fai clic con il pulsante destro del mouse su una riga di codice nell'editor di testo nella funzione o nella routine di cui vuoi eseguire il debug. Seleziona Punto di interruzione, Inserisci punto di interruzione. Il punto di interruzione viene aggiunto e la riga di codice viene evidenziata in rosso.
Nel menu Debug seleziona Avvia debug per generare, implementare e testare il progetto. Verrà eseguito lo script di test in
Test.sql
e verrà richiamato l'oggetto di database gestito.Quando la freccia gialla (che indica il puntatore all'istruzione) viene visualizzata in corrispondenza del punto di interruzione, l'esecuzione del codice viene sospesa. È quindi possibile eseguire il debug dell'oggetto di database gestito:
- Usa Passaggio dal menu Debug per spostare il puntatore dell'istruzione alla riga di codice successiva.
- Usa la finestra Locali per osservare lo stato degli oggetti attualmente evidenziati dal puntatore dell'istruzione.
- Aggiungere variabili alla finestra Espressioni di controllo. È possibile osservare lo stato delle variabili osservate in tutta la sessione di debug, anche quando la variabile non si trova nella riga di codice attualmente evidenziata dal puntatore delle istruzioni.
- Seleziona Continua dal menu Debug per fare avanzare il puntatore dell'istruzione al successivo punto di interruzione o per completare l'esecuzione della routine se non sono presenti altri punti di interruzione.
Codice di esempio
L'esempio C# seguente restituisce la versione di SQL Server al chiamante.
using System.Data.SqlClient;
using Microsoft.SqlServer.Server;
public class StoredProcedures
{
[Microsoft.SqlServer.Server.SqlProcedure]
public static void GetVersion()
{
using (var connection = new SqlConnection("context connection=true"))
{
connection.Open();
var command = new SqlCommand("select @@version", connection);
SqlContext.Pipe.ExecuteAndSend(command);
}
}
}
Script di test di esempio
Lo script di test seguente illustra come richiamare la stored procedure GetVersion
definita nell'esempio precedente.
EXECUTE GetVersion;