Как вызвать код C# из Sql Server

1. делаем библиотеку классов и переносим DLL на сервере
namespace CLRFalconLib
{

public class BaseFunctionClass
{
#region “Default Constructor”
public BaseFunctionClass()
{

}
#endregion

#region “Welcome Function”
///

/// This function will be called from the SQL Stored Procedure.
///

///Name /// Welcome Message
[SqlProcedure] public static int GetMessage2(SqlString strName, out SqlString strMessge)
{
strMessge = “Welcome your code is getting executed under CLR !”;
return 5;
}

[SqlProcedure] public static void GetMessage(SqlString strName, out SqlString strMessge)
{
strMessge = “Welcome your code is getting executed under CLR !”;

}
#endregion

}
}

2. Делаем возможным вызов CLR из sql (делаем на сервере под админом)
sp_configure ‘clr enable’, 1
GO
RECONFIGURE
GO

3. Создание сборки в sql (и ее обновление когда необходимо перезалить dll)
CREATE ASSEMBLY CLRFalconLib2
AUTHORIZATION dbo
FROM ‘C:\Temp\CLRFalconLib.dll’
WITH PERMISSION_SET = UNSAFE
GO

ALTER ASSEMBLY CLRFalconLib
FROM ‘C:\Temp\CLRFalconLib.dll’

4. Создаем процедуру которую будем потом вызывать
CREATE PROCEDURE tst_UseHelloDotNetAssembly2
@name nvarchar(200),
@msg nvarchar(MAX)OUTPUT
AS EXTERNAL NAME CLRFalconLib.[CLRFalconLib.BaseFunctionClass].GetMessage2
GO

5. Вызов процедуры
DECLARE @id int , @msg varchar(MAX)=”
EXEC @id = tst_UseHelloDotNetAssembly2 ‘Kittu And Tannu’,@msg output
PRINT @msg
print @id

Более подробно:

https://www.codeproject.com/Articles/19954/Execute-NET-Code-under-SQL-Server
http://techxposer.com/2017/08/21/calling-rest-api-service-from-sql-server-using-c-sql-clr/
https://blog.sqlauthority.com/2008/10/19/sql-server-introduction-to-clr-simple-example-of-clr-stored-procedure/

Руслан Раянов

Share
Published by
Руслан Раянов
Tags: SQL Server

Recent Posts

Что такое Customer Development (кастдев)? #понятия_веб_разработки #вебликбез

https://falconspace.ru/blog/bazovye-voprosy-i-ponyatiya-v-sfere-sozdaniya-veb-proektov - Основы веб-разработки. Базовые понятия для владельца сайта

12 часов ago

Что такое Целевая аудитория? #понятия_веб_разработки #вебликбез

https://falconspace.ru/blog/bazovye-voprosy-i-ponyatiya-v-sfere-sozdaniya-veb-proektov - Основы веб-разработки. Базовые понятия для владельца сайта

1 день ago

Что такое Концепция сайта? Что такое Бриф на разработку сайта? #понятия_веб_разработки #вебликбез

https://falconspace.ru/blog/bazovye-voprosy-i-ponyatiya-v-sfere-sozdaniya-veb-proektov - Основы веб-разработки. Базовые понятия для владельца сайта

2 дня ago

Каким должен быть личный кабинет информационной системы?

Вероятно, у вас есть сайт и вы подумываете, что было бы неплохо внедрить в него…

3 дня ago

Что такое Итерация, этап, спринт? #понятия_веб_разработки #вебликбез

https://falconspace.ru/blog/bazovye-voprosy-i-ponyatiya-v-sfere-sozdaniya-veb-proektov - Основы веб-разработки. Базовые понятия для владельца сайта

6 дней ago

Что такое Рейт эстимейт почасовая ставка? #понятия_веб_разработки #вебликбез

https://falconspace.ru/blog/bazovye-voprosy-i-ponyatiya-v-sfere-sozdaniya-veb-proektov - Основы веб-разработки. Базовые понятия для владельца сайта

1 неделя ago