3 / 3 / 8
Регистрация: 14.10.2012
Сообщений: 288
1

Проблема с созданием CLR (C#) функции

27.10.2016, 04:52. Показов 1868. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, создаю библиотеку в VisualStudio с методом, который бы возвращал информацию о файлах и импортирую метод в MS SQL, но что-то не получается.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
using System;
using System.Collections.Generic;
using System.IO;
using System.Linq;
using System.Security.AccessControl;
using System.Security.Principal;
using System.Data.Sql;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
using System.Text;
using System.Threading.Tasks;
using System.Collections;
 
namespace ClassLibrary4
{
    public class Class1
    {
        [Microsoft.SqlServer.Server.SqlFunction(FillRowMethodName = "FillRow",
            TableDefinition = "FileInfo nvarchar(max)")]
        public static IEnumerable GetDir(string DirName)
        {
            DirectoryInfo startDir = new DirectoryInfo(DirName);
            return startDir.GetFiles();
        }
 
        public static void FillRow(object row, out string result)
        {
            result = null;
            DirectoryInfo d = new DirectoryInfo((string)row);
            DirectorySecurity ds = d.GetAccessControl();
            foreach (FileSystemAccessRule permissions in ds.GetAccessRules(true, true, typeof(NTAccount)))
            {
                result =  permissions.IdentityReference.Translate(typeof(NTAccount)).Value;
               result += permissions.FileSystemRights.ToString();
            }
        }
    }
}
T-SQL
1
2
3
4
5
6
7
8
9
10
11
12
13
drop function GetDircontents
drop assembly SqlTVFExternalAccess
CREATE ASSEMBLY SqlTVFExternalAccess
FROM 'D:\5 семестр\БД\4\ClassLibrary4\ClassLibrary4\obj\Debug\ClassLibrary4.dll'
 
CREATE FUNCTION GetDircontents(@DirName nvarchar(max))
RETURNS TABLE
(
    FileInfo NVARCHAR(max)
)
AS
EXTERNAL NAME SqlTVFExternalAccess.[ClassLibrary4.Class1].FillRow
GO
Пишет выполнить не удалось, так как типы T-SQL и CLR для возвращаемого значения не совпадают
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
27.10.2016, 04:52
Ответы с готовыми решениями:

Проблема с созданием разделов
Раньше у меня был XP и было там 3 диска: С,Д,Е. Все нужные файлы я скинул на Е. При установке вин7...

Проблема с созданием классов
Проблема с создованием классов в IDE такая: Создал классы в visual добавить->класс Все отлично...

Проблема с созданием документа(
Конфигурация 7.7 С помощью обработки нужно создать документ (в конфигураторе указан Журнал для...

Проблема с созданием формы
Нужно создать дополнителную форму, которая появится при нажатии на кнопку. Пробовал в дельфи ...

1
Администратор
Эксперт .NET
16328 / 12817 / 5060
Регистрация: 17.03.2014
Сообщений: 26,086
Записей в блоге: 1
28.10.2016, 20:23 2
Nike1995, похоже надо указать GetDir вместо FillRow в CREATE FUNCTION ... EXTERNAL NAME
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.10.2016, 20:23
Помогаю со студенческими работами здесь

Проблема с созданием запроса
Здравствуйте! Имеется база данных, в таблице есть значения марка материала и гост, ...

Проблема с созданием дистрибутива.
Я создала дистрибутив при помощи InstallShield'а на компьютере,где стоит winXP и Visual Studio...

Проблема с созданием экземпляра БД
Стоит Oracle 7.3 и windows XP имеется в наличии 1) холодный бекап базы 2) init.ora ...

Проблема с созданием подписи
Lotus Domino 8.5.3 FP6 на одном из почтовых файлов пропала возможность настроить подпись т.е. в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru