0 / 0 / 2
Регистрация: 11.06.2015
Сообщений: 60

Триггеры CLR

12.03.2017, 21:46. Показов 1922. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем доброго времени суток. По этомуhttp://https://msdn.microsoft.com/ru-ru/library/microsoft.sqlserver.server.sqltriggercontext(v=vs.110).aspx примеру создаю триггер. Таблица, создается и заполняется с использованием EF6. Мне необходимо чтобы триггер срабатывал в момент обновления(вставки данных).

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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
namespace TriggerInAction
{
    public enum Status
    {
        Normal,
        Middle,
        Top,
        Vip
    }
 
    public class Customer
    {
        public int CustomerId { get; set; }
 
        public string Name { get; set; }
 
        public int OrdersAmount { get; set; }
 
        public Status _Status { get; set; }
    }
 
    public class CustomerContext : DbContext
    {
        public CustomerContext() : 
            base("CustomerAudit")
        {
 
        }
 
        public DbSet<Customer> Customers { get; set; }
    }
 
 
    class Program
    {
        static void Main(string[] args)
        {
            //КАК ВЫЗВАТЬ ТРИГГЕР
            Customer customer ;
            try
            {
                
                using (CustomerContext context = new CustomerContext())
                {
                    for (int i = 0; i < 2; i++)
                    {
                        customer = new Customer();
                        customer.Name = Guid.NewGuid().ToString();
                        customer.OrdersAmount = i + 4;
                        context.Customers.Add(customer);
                    }
 
                    context.SaveChanges();
                    
                    foreach (var item in context.Customers)
                    {
                       // StatusAudit();
                        Console.WriteLine("Customer Name = {0}, Customer Status = {1}", item.Name, item._Status);
                    }
                }
            }
            catch(Exception ex)
            {
                Console.WriteLine(ex.Message);
            }
        }
 
        [SqlTrigger(Name = @"StatusAudit", Target = "[dbo].[Customers]", Event = "FOR INSERT, UPDATE")]
        public static void StatusAudit()
        {
            SqlCommand command;
            SqlTriggerContext triggContext = SqlContext.TriggerContext;
            SqlPipe pipe = SqlContext.Pipe;
            SqlDataReader reader;
 
            Customer customer = new Customer();
            string cmdStr = "Insert Into Customers (Status) Values(@Status)";
 
            switch (triggContext.TriggerAction)
            {
                case TriggerAction.Insert:
                    // Retrieve the connection that the trigger is using  
                    using (SqlConnection connection
                       = new SqlConnection(@"context connection=true"))
                    {
                        connection.Open();
                        command = new SqlCommand(@"SELECT * FROM INSERTED;",
                           connection);
                        reader = command.ExecuteReader();
                        reader.Read();
                        customer.OrdersAmount = int.Parse(reader[2].ToString());
                        
                        reader.Close();
 
 
                        if (customer.OrdersAmount < 5)
                        {
                            using (SqlCommand cmd = new SqlCommand(cmdStr, connection))
                            {
                                cmd.Parameters.AddWithValue("@Status", Status.Normal);
                                cmd.ExecuteNonQuery();
                            }
                        }
 
                        if (customer.OrdersAmount >= 5)
                        {
                            using (SqlCommand cmd = new SqlCommand(cmdStr, connection))
                            {
                                cmd.Parameters.AddWithValue("@Status", Status.Vip);
                                cmd.ExecuteNonQuery();
                            }
                        }
                    }
 
                    break;
            }
        }
    }
}
Подскажите, где необходимо вызывать метод StatusAudit(). Если вызываю сразу после метода context.SaveChanges(), выскакивает исключение : Для затребованной операции необходим контекст SqlClr, который доступен только при выполнении в процессе Sql Server.. Триггер необходимо создавать именно в c# коде, т.к. база должна создаваться именно в момент первого запуска приложения. Подскажите, как это реализовать?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.03.2017, 21:46
Ответы с готовыми решениями:

Entity Framework и триггеры БД
Добрый день. Проблема вот в чем. Данные в БД изменяются с помощью триггеров (без участия Entity Framework), однако контекст этих...

CLR сборка и ее вызов
Добрый день! Есть сборка (это ее часть) public static string fn_fk1_getdata(string xml, string url) { ......

COM в хранимой процедуре CLR
Есть MS SQL 2005. Нужно написать хранимую процедуру CLR в которой будет вызываться COM объект. Возможно это? Если в ней написать что то...

6
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18310 / 14234 / 5368
Регистрация: 17.03.2014
Сообщений: 28,905
Записей в блоге: 1
12.03.2017, 22:01
plusok, триггер не нужно вызывать. Его нужно настроить на стороне SQL Server и он будет автоматически вызван.
0
0 / 0 / 2
Регистрация: 11.06.2015
Сообщений: 60
12.03.2017, 22:06  [ТС]
А это возможно если база еще не создана?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18310 / 14234 / 5368
Регистрация: 17.03.2014
Сообщений: 28,905
Записей в блоге: 1
12.03.2017, 22:07
plusok, а ты как думаешь?
0
0 / 0 / 2
Регистрация: 11.06.2015
Сообщений: 60
12.03.2017, 22:13  [ТС]
Мне кажется нет. Правильно?
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18310 / 14234 / 5368
Регистрация: 17.03.2014
Сообщений: 28,905
Записей в блоге: 1
12.03.2017, 22:15
plusok, разумеется. Триггер же привязывается к существующей таблице. Если нет базы, то нет и таблицы, а следовательно и триггера.
0
0 / 0 / 2
Регистрация: 11.06.2015
Сообщений: 60
12.03.2017, 22:17  [ТС]
БОЛЬШОЕ СПАСИБО. Помогли сэкономить время на бессмысленных поисках.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.03.2017, 22:17
Помогаю со студенческими работами здесь

SQL триггеры, база данных
CREATE TRIGGER DEL ON &quot;Address&quot; INSTEAD OF DELETE AS DECLARE @Deleted INT SELECT @Deleted=Addr_ID FROM deleted PRINT @Deleted ...

System.Drawing в CLR-процедуре
Есть сервер SQL2005, на VS2005 нужно написать внешнюю хранимку в которой нужно создать картинку. В обыкновенном проекте всё понятно как...

CLR функция с таблицей в качестве входного параметра
Можно ли сделать CLR функцию, на вход которой будет подаваться таблица? Если да, то покажите какой-нибудь простейший пример, где есть таю...

Создание файлов в FileTable по UNC-пути к каталогу из CLR SQL
Привет! Есть тестовая процедурка, написанная на C# CLR SQL, которая потом работает как обычная хранимка. Процедура пытается создать файл в...

Хитрости CLR.
Здравствуйте! Есть 2 вопроса-проблемы. 1) Есть сборка, в ней объект. Объект и сборка эволюционируют и соответственно имеются их разные...


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

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

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru