Форум программистов, компьютерный форум, киберфорум
C#: Базы данных, ADO.NET
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
0 / 0 / 2
Регистрация: 11.06.2015
Сообщений: 60
1

Триггеры CLR

12.03.2017, 21:46. Просмотров 813. Ответов 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
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
12.03.2017, 21:46
Ответы с готовыми решениями:

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

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

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

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

6
Супер-модератор
Эксперт .NET
12687 / 10390 / 4322
Регистрация: 17.03.2014
Сообщений: 20,928
Записей в блоге: 1
12.03.2017, 22:01 2
plusok, триггер не нужно вызывать. Его нужно настроить на стороне SQL Server и он будет автоматически вызван.
0
0 / 0 / 2
Регистрация: 11.06.2015
Сообщений: 60
12.03.2017, 22:06  [ТС] 3
А это возможно если база еще не создана?
0
Супер-модератор
Эксперт .NET
12687 / 10390 / 4322
Регистрация: 17.03.2014
Сообщений: 20,928
Записей в блоге: 1
12.03.2017, 22:07 4
plusok, а ты как думаешь?
0
0 / 0 / 2
Регистрация: 11.06.2015
Сообщений: 60
12.03.2017, 22:13  [ТС] 5
Мне кажется нет. Правильно?
0
Супер-модератор
Эксперт .NET
12687 / 10390 / 4322
Регистрация: 17.03.2014
Сообщений: 20,928
Записей в блоге: 1
12.03.2017, 22:15 6
plusok, разумеется. Триггер же привязывается к существующей таблице. Если нет базы, то нет и таблицы, а следовательно и триггера.
0
0 / 0 / 2
Регистрация: 11.06.2015
Сообщений: 60
12.03.2017, 22:17  [ТС] 7
БОЛЬШОЕ СПАСИБО. Помогли сэкономить время на бессмысленных поисках.
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
12.03.2017, 22:17

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

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

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

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

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


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2021, vBulletin Solutions, Inc.