Compilazione di oggetti di database con l'integrazione con CLR (Common Language Runtime)
È possibile compilare oggetti di database utilizzando l'integrazione di SQL Server con CLR (Common Language Runtime) di .NET Framework. Il codice gestito eseguito in Microsoft SQL Server viene definito "routine CLR". Queste routine includono gli elementi seguenti:
Funzioni definite dall'utente con valori scalari
Funzioni definite dall'utente con valori di tabella
Procedure definite dall'utente
Trigger definiti dall'utente
Le routine CLR hanno la stessa struttura in codice gestito. Viene eseguito il mapping di tali routine a metodi pubblici e statici (condivisi in Microsoft Visual Basic .NET) di una classe. Oltre alle routine, è possibile definire tipi definiti dall'utente e funzioni di aggregazione definite dall'utente utilizzando .NET Framework. Viene eseguito il mapping dei tipi definiti dall'utente (UDT) e delle aggregazioni definite dall'utente a intere classi di .NET Framework.
Ogni tipo di routine .NET Framework include una dichiarazione Transact-SQL e può essere utilizzato in SQL Server ovunque sia possibile utilizzare l'equivalente Transact-SQL. Le funzioni scalari definite dall'utente, ad esempio, possono essere utilizzate in qualsiasi espressione scalare. Una funzione con valori di tabella può essere utilizzata in qualsiasi clausola FROM. Una procedura può essere richiamata in un'istruzione EXEC o da un'applicazione client.
[!NOTA]
L'esecuzione di un oggetto CLR (funzione definita dall'utente, tipo definito dall'utente o trigger) sul Common Language Runtime può avvenire su più thread (piano parallelo), se il Query Optimizer decide che è vantaggioso. Tuttavia, se una funzione definita dall'utente accede ai dati, l'esecuzione sarà su un piano seriale. Anche in caso di esecuzione in una versione server precedente a SQL Server 2008 e se in una funzione definita dall'utente sono contenuti parametri LOB o valori restituiti, l'esecuzione deve essere su un piano seriale.
Nella tabella seguente sono elencati gli argomenti inclusi in questa sezione.
Introduzione all'integrazione con CLR
Include una breve panoramica delle librerie e degli spazi dei nomi necessari per compilare l'oggetto utilizzando l'integrazione con CLR con SQL Server. È inclusa una stored procedure CLR "Hello World" di esempio.Librerie .NET Framework supportate
Include informazioni sulle librerie .NET Framework supportate dall'integrazione CLR.Restrizioni relative al modello di programmazione dell'integrazione con CLR
Include informazioni sulle restrizioni del modello di programmazione dell'integrazione CLR.Tipi di dati di SQL Server in .NET Framework
Panoramica dei tipi di dati di SQL Server e degli equivalenti di .NET Framework.Panoramica degli attributi personalizzati dell'integrazione con CLR
Include informazioni sugli attributi personalizzati dell'integrazione CLR.Funzioni CLR definite dall'utente
Viene descritto come implementare e utilizzare i diversi tipi di funzioni CLR, ovvero le funzioni con valori di tabella, le funzioni scalari e le funzioni di aggregazione definite dall'utente.Tipi CLR definiti dall'utente
Viene descritto come implementare e utilizzare i tipi CLR definiti dall'utente.Stored procedure CLR
Viene descritto come implementare e utilizzare le stored procedure CLR.Trigger CLR
Viene descritto come implementare e utilizzare i trigger CLR.
Vedere anche
Altre risorse
Panoramica dell'integrazione con CLR (Common Language Runtime)