Sdílet prostřednictvím


Použití ověřitelných sestavení se serverem SQL Server (C++/CLI)

Rozšířené uložené procedury jsou reprezentovány ve formě dynamických knihoven (DLL), umožňují rozšiřovat funkce systému SQL Server pomocí funkcí vytvořených s Visual C++.Rozšířené uložené procedury jsou implementovány jako funkce uvnitř knihoven DLL.Kromě funkcí mohou rozšířené uložené procedury také definovat uživatelem definované typy a souhrnné funkce (například SUM nebo AVG).

Poté, co klient spustí rozšířenou uloženou proceduru, SQL Server hledá knihovnu DLL přidruženou k rozšířené uložené proceduře a načte ji.SQL Server volá požadovanou rozšířenou uloženou proceduru a spustí ji v rámci zadaného kontextu zabezpečení.Rozšířená uložená procedura poté předá sady výsledků a vrátí parametry na server.

SQL Server 2005 poskytuje rozšíření Transact-SQL (T-SQL) tak, aby bylo možné instalovat ověřitelná sestavení na SQL Server.Sada oprávnění systému SQL Server určuje kontext zabezpečení s následujícími úrovněmi zabezpečení:

  • Neomezený režim: spustit kód na vlastní nebezpečí; být ověřovatelný kód nemá.

  • Nouzový režim: spustit prokazatelně ověřitelný kód; kompilovaný s/clr: safe.

Bezpečný režim vyžaduje, aby bylo spuštěné sestavení ověřitelné zajišťující bezpečnost typů.

Chcete-li vytvořit a nahrát ověřitelné sestavení na SQL Server, použijte příkazy jazyka Transact-SQL CREATE ASSEMBLY a DROP ASSEMBLY takto:

CREATE ASSEMBLY <assemblyName> FROM <'Assembly UNC Path'> WITH 
  PERMISSION_SET <permissions>
DROP ASSEMBLY <assemblyName>

Příkaz PERMISSION_SET určuje kontext zabezpečení a může nabývat hodnot UNRESTRICTED, SAFE nebo EXTENDED.

Kromě toho můžete použít příkaz CREATE FUNCTION pro vytvoření vazby na názvy metod ve třídě:

CREATE FUNCTION <FunctionName>(<FunctionParams>)
RETURNS returnType
[EXTERNAL NAME <AssemblyName>:<ClassName>::<StaticMethodName>]

Příklad

Následující skript SQL (například "MyScript.sql") nahraje sestavení na SQL Server a zpřístupní metodu třídy:

-- Create assembly without external access
drop assembly stockNoEA
go
create assembly stockNoEA
from 
'c:\stockNoEA.dll'
with permission_set safe

-- Create function on assembly with no external access
drop function GetQuoteNoEA
go
create function GetQuoteNoEA(@sym nvarchar(10))
returns real
external name stockNoEA:StockQuotes::GetQuote
go

-- To call the function
select dbo.GetQuoteNoEA('MSFT')
go

Skripty SQL mohou být provedeny interaktivně v nástroji SQL Query Analyzer nebo na příkazovém řádku pomocí nástroje sqlcmd.exe.Následující příkaz na příkazovém řádku se připojí k serveru MyServer, použije výchozí databázi, důvěryhodné připojení, vstup MyScript.sql a výstup MyResult.txt.

sqlcmd –S MyServer -E –i myScript.sql –o myResult.txt

Viz také

Referenční dokumentace

Postupy: Přechod na /clr:safe (C++/CLI)

Třídy, struktury a spojení