Форум программистов, компьютерный форум, киберфорум
Microsoft SQL Server
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.91/11: Рейтинг темы: голосов - 11, средняя оценка - 4.91
3 / 3 / 8
Регистрация: 14.10.2012
Сообщений: 288

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

27.10.2016, 04:52. Показов 2080. Ответов 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
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
27.10.2016, 04:52
Ответы с готовыми решениями:

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

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

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

1
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18304 / 14228 / 5368
Регистрация: 17.03.2014
Сообщений: 28,902
Записей в блоге: 1
28.10.2016, 20:23
Nike1995, похоже надо указать GetDir вместо FillRow в CREATE FUNCTION ... EXTERNAL NAME
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.10.2016, 20:23
Помогаю со студенческими работами здесь

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

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

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

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

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


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru