Condividi tramite


Compilazione di oggetti di database con integrazione CLR (Common Language Runtime)

È possibile compilare oggetti di database usando Microsoft SQL Server è definito "routine CLR". Queste routine includono:

  • 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. Vengono mappati a metodi statici e pubblici (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 di .NET Framework ha un'istanza di SQL Server che può essere usata dall'Transact-SQL equivalente. Le funzioni scalari definite dall'utente, ad esempio, possono essere utilizzate in qualsiasi espressione scalare. Un valore TVF può essere usato in qualsiasi clausola FROM. Una routine può essere richiamata in un'istruzione EXEC o richiamata da un'applicazione client.

Annotazioni

L'esecuzione di un oggetto CLR (funzione definita dall'utente, tipo definito dall'utente o trigger) in Common Language Runtime può essere eseguita su più thread (piano parallelo), se Query Optimizer decide che è utile. Tuttavia, se una funzione definita dall'utente accede ai dati, l'esecuzione sarà in un piano seriale. Se eseguita in una versione del server precedente a SQL Server 2008, se una funzione definita dall'utente contiene parametri LOB o valori restituiti, l'esecuzione deve essere anche in un piano seriale.

Nella tabella seguente sono elencati gli argomenti trattati in questa sezione.

Introduzione all'integrazione con CLR
Viene fornita una breve panoramica delle librerie e degli spazi dei nomi necessari per compilare l'oggetto usando 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 del modello di programmazione dell'integrazione 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 dei relativi equivalenti .NET Framework.

Panoramica degli attributi personalizzati dell'integrazione con CLR
Include informazioni sugli attributi personalizzati dell'integrazione CLR.

Funzioni CLR User-Defined
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 User-Defined
Viene descritto come implementare e utilizzare i tipi CLR definiti dall'utente.

Procedure memorizzate CLR
Viene descritto come implementare e utilizzare le stored procedure CLR.

Trigger CLR
Viene descritto come implementare e utilizzare i trigger CLR.

Vedere anche

Panoramica dell'integrazione di Common Language Runtime (CLR)