Передать переменную в триггер - PullRequest
16 голосов
/ 15 апреля 2010

У меня есть trigger, который имеет дело с некоторыми данными для целей ведения журнала, например:

CREATE TRIGGER trgDataUpdated
   ON tblData FOR UPDATE
AS 
BEGIN
    INSERT INTO tblLog ( ParentID, OldValue, NewValue, UserID )
    SELECT  deleted.ParentID, deleted.Value, inserted.Value, 
            @intUserID -- how can I pass this in?
    FROM    inserted INNER JOIN deleted ON inserted.ID = deleted.ID
END

Как передать переменную @intUserID в вышеуказанный триггер, как в следующем коде:

DECLARE @intUserID int
SET @intUserID = 10

UPDATE tblData
SET    Value = @x

PS: я знаю, что не могу буквально передать @intUserID триггеру, он просто использовался для иллюстрации.

Ответы [ 6 ]

10 голосов
/ 15 апреля 2010

Я использую SET CONTEXT_INFO для такого рода действий. Это ссылка 2008+, предыдущая ссылка удалена.

В SQL Server 2005+ вам потребуется CONTEXT_INFO, чтобы прочитать его, но в противном случае вы должны получить из столбца context_info в dbo.sysprocesses.

5 голосов
/ 15 апреля 2010

вы не можете передать переменную в триггер.

единственный способ получить информацию в триггере - это иметь возможность ВЫБРАТЬ ее на основе таблиц INSERTED или DELETED или добавить столбец в соответствующую таблицу и поместить значение в этот столбец.

РЕДАКТИРОВАТЬ в предыдущем вопросе ОП, опубликованном по этому поводу, они сказали, что не хотят использовать CONTEXT_INFO, но здесь они говорят, что это нормально, поэтому вот пример использования CONTEXT_INFO:

в процедуре выполнения обновления

DECLARE @intUserID     int
       ,@CONTEXT_INFO  varbinary(128)
SET @intUserID = 10
SET @CONTEXT_INFO =cast('intUserID='+CONVERT(varchar(10),@intUserID)+REPLICATE(' ',128) as varbinary(128))
SET CONTEXT_INFO @CONTEXT_INFO

--do update that will fire the trigger

SET CONTEXT_INFO 0x0 

вот часть триггера для получения значения:

DECLARE @intUserID     int
       ,@sCONTEXT_INFO  varchar(128)
SELECT @sCONTEXT_INFO=CAST(CONTEXT_INFO() AS VARCHAR) FROM master.dbo.SYSPROCESSES WHERE SPID=@@SPID

IF LEFT(@sCONTEXT_INFO,9)='intUserID'
BEGIN
    SET @intUserID=RIGHT(RTRIM(@sCONTEXT_INFO),LEN(RTRIM(@sCONTEXT_INFO))-10)
END
ELSE
BEGIN
    RAISERROR('intUserID was not specified',16,1)
    ROLLBACK TRAN
    RETURN
END

..use the @intUserID
1 голос
/ 01 апреля 2018

Старый вопрос, но мне интересно, почему никто не упомянул, что временные таблицы, созданные до вызова триггера, видны в триггере? Итак, это будет работать:

SELECT 10 intUserID INTO #intUserID

UPDATE tblData
SET    Value = @x

Триггер увидит временную таблицу #intUserID и сможет прочитать оттуда идентификатор.

1 голос
/ 15 апреля 2010

Вы не можете передавать переменные в триггеры. В зависимости от того, как пользователи подключаются к базе данных, вы можете использовать SYSTEM_USER для подключения текущего пользователя к базе данных.

0 голосов
/ 21 июня 2012

Почему бы не попробовать это:

CREATE TRIGGER trgDataUpdated
   ON tblData FOR UPDATE
AS 
BEGIN
    EXECUTE tbLogUpdate intUserId
END
0 голосов
/ 15 апреля 2010

Вы не передаете переменные триггерам, потому что не можете напрямую вызывать триггеры. Они выполняются в результате вставки, изменения или удаления данных.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...