Freigeben über


Erstellen von CLR-Funktionen

In SQL Server 2005 können Sie ein Datenbankobjekt innerhalb einer Instanz von SQL Server erstellen, das in einer Assembly programmiert ist, das in Microsoft .NET Framework CLR (Common Language Runtime) erstellt ist. Datenbankobjekte, die das reichhaltige Programmiermodell nutzen können, das von der Common Language Runtime bereitgestellt wird, sind z. B. Aggregatfunktionen, Funktionen, gespeicherte Prozeduren, Trigger und Typen.

Zum Erstellen einer CLR-Funktion in SQL Server müssen folgende Schritte ausgeführt werden:

  • Definieren der Funktion als statische Methode einer Klasse in einer Sprache, die von .NET Framework unterstützt wird. Weitere Informationen zum Programmieren von Funktionen in der Common Language Runtime finden Sie unter CLR User-Defined Functions. Kompilieren Sie die Klasse mithilfe des entsprechenden Sprachcompilers, um eine Assembly in .NET Framework zu erstellen.
  • Registrieren der Assembly in SQL Server mithilfe der CREATE ASSEMBLY-Anweisung. Weitere Informationen zu Assemblys in SQL Server finden Sie unter Assemblys (Database Engine).
  • Erstellen der Funktion, die auf die registrierte Assembly verweist, mithilfe der CREATE FUNCTION-Anweisung.
ms189876.note(de-de,SQL.90).gifHinweis:
Bei der Bereitstellung eines SQL Server-Projekts in Microsoft Visual Studio wird eine Assembly in der Datenbank registriert, die für das Projekt angegeben wurde. Bei der Bereitstellung des Projekts werden auch CLR-Funktionen in der Datenbank für alle Methoden erstellt, die mit dem SqlFunction-Attribut versehen sind. Weitere Informationen finden Sie unter Deploying CLR Database Objects.
ms189876.note(de-de,SQL.90).gifHinweis:
Die Funktion zum Ausführen von CLR-Code ist in SQL Server standardmäßig deaktiviert. Sie können Datenbankobjekte, die auf verwaltete Codemodule verweisen, erstellen, ändern oder löschen; diese Verweise werden jedoch nur dann in SQL Server ausgeführt, wenn die Option clr enabled mithilfe von sp_configure (Transact-SQL) aktiviert wird.

Zugreifen auf externe Ressourcen

CLR-Funktionen können verwendet werden, um auf externe Ressourcen wie z. B. Dateien, Netzwerkressourcen, Webdienste oder andere Datenbanken (einschließlich Remoteinstanzen von SQL Server) zuzugreifen. Hierzu können in .NET Framework verschiedene Klassen verwendet werden, wie System.IO, System.WebServices, System.Sql usw. Die Assembly, die solche Funktionen enthält, sollte für diesen Zweck mindestens mit der EXTERNAL_ACCESS-Berechtigung konfiguriert werden. Weitere Informationen finden Sie unter CREATE ASSEMBLY (Transact-SQL). Der verwaltete Anbieter von SQL Client kann für den Zugriff auf Remoteinstanzen von SQL Server verwendet werden. Loopbackverbindungen mit dem ursprünglichen Server werden in CLR-Funktionen jedoch nicht unterstützt.

So erstellen, ändern oder löschen Sie Assemblys in SQL Server

So erstellen Sie eine CLR-Funktion

Siehe auch

Konzepte

Erstellen von benutzerdefinierten Funktionen (Datenbankmodul)
Erstellen benutzerdefinierter Aggregate
Ausführen benutzerdefinierter Funktionen (Datenbankmodul)
Anzeigen benutzerdefinierter Funktionen

Andere Ressourcen

Database Engine .NET Framework Programming

Hilfe und Informationen

Informationsquellen für SQL Server 2005