在SQL觸發(fā)器或存儲(chǔ)過(guò)程中獲取在程序登錄的用戶(hù)
每個(gè)用戶(hù)可以登錄系統(tǒng),在程序中操作數(shù)據(jù)(添加,更新和刪除)需要實(shí)現(xiàn)記錄操作跟蹤。是誰(shuí)添加,更新和刪除的,這些信息將會(huì)插入至AuditLog表中。
一般情況之下,在SQL的觸發(fā)器中,只能取到(SQL驗(yàn)證sa;Windows驗(yàn)證Domain\xxx)。這些用戶(hù)名,達(dá)不到效果,不能真正反映到是誰(shuí)操作的。
下面是讓你清楚,怎樣實(shí)現(xiàn)在SQL觸發(fā)器或存儲(chǔ)過(guò)程中獲取在程序登錄的用戶(hù),是在插入,更新或刪除的存儲(chǔ)過(guò)程,把登錄程序當(dāng)前用戶(hù)傳入進(jìn)去。在存儲(chǔ)過(guò)程中,再把相關(guān)信息存入局部(#)臨時(shí)表中,這樣子,在觸發(fā)器即可獲取了。
下面代碼示例,以一個(gè)[Member]表作例,可以參詳:
Member
CREATE TABLE Member
(
Member_nbr INT IDENTITY(1,1) PRIMARY EKY NOT NULL,
[Name] NVARCHAR(30),
Birthday DATETIME,
Email NVARCHAR(100),
[Address] NVARCHAR(100)
)
GO
插入存儲(chǔ)過(guò)程:
MemberSp_Insert
CREATE PROCEDURE MemberSp_Insert
(
--Other parameter
@Operater NVARCHAR(50) --帶到此參數(shù),可從程序的用戶(hù)傳至數(shù)據(jù)庫(kù)
)
AS
BEGIN
--處理插入事務(wù)
---INSERT INTO [dbo].[Member] (xxx) VALUES(xxx)
--把相關(guān)信息存入臨時(shí)表,方便在觸發(fā)器時(shí)取到。
IF OBJECT_ID('#AuditWho') IS NOT NULL
DROP TABLE [#AuditWho]
CREATE TABLE [#AuditWho] (PrimaryKey INT,Operater NVARCHAR(50))
INSERT INTO [#AuditWho] VALUES(SCOPE_IDENTITY(),@Operater)
END
GO
更新存儲(chǔ)過(guò)程:
MemberSp_Update
CREATE PROCEDURE MemberSp_Update
(
--Other parameter
@Member_nbr INT,
@Operater NVARCHAR(50) --帶到此參數(shù),可從程序的用戶(hù)傳至數(shù)據(jù)庫(kù)
)
AS
BEGIN
--處理更新事務(wù)
---UPDATE [dbo].[Member] SET [xxx] = xxx, ... WHERE [Member_nbr] = @Member_nbr
--把相關(guān)信息存入臨時(shí)表,方便在觸發(fā)器時(shí)取到。
IF OBJECT_ID('#AuditWho') IS NOT NULL
DROP TABLE [#AuditWho]
CREATE TABLE [#AuditWho] (PrimaryKey INT,Operater NVARCHAR(50))
INSERT INTO [#AuditWho] VALUES(@Member_nbr,@Operater)
END
GO
刪除存儲(chǔ)過(guò)程:
MemberSp_Delete
CREATE PROCEDURE MemberSp_Delete
(
@Member_nbr INT,
@Operater NVARCHAR(50) --帶到此參數(shù),可從程序的用戶(hù)傳至數(shù)據(jù)庫(kù)
)
AS
BEGIN
--處理刪除事務(wù)
---DELETE FROM [dbo].[Member] WHERE [Member_nbr] = @Member_nbr
--把相關(guān)信息存入臨時(shí)表,方便在觸發(fā)器時(shí)取到。
IF OBJECT_ID('#AuditWho') IS NOT NULL
DROP TABLE [#AuditWho]
CREATE TABLE [#AuditWho] (PrimaryKey INT,Operater NVARCHAR(50))
INSERT INTO [#AuditWho] VALUES(@Member_nbr,@Operater)
END
GO
從上面的存儲(chǔ)過(guò)程,用戶(hù)相關(guān)的信息(應(yīng)用程序的用戶(hù)信息)已經(jīng)在存儲(chǔ)過(guò)程中存入臨時(shí)表中,接下來(lái),在觸發(fā)器,怎樣獲取呢??梢詤⒖枷旅娴挠|發(fā)器代碼:
插入觸發(fā)器:
MemberTr_Insert
CREATE TRIGGER [dbo].[MemberTr_Insert]
ON [dbo].[Member]
FOR INSERT
AS
BEGIN
IF @@ROWCOUNT = 0 RETURN
SET NOCOUNT ON
--事務(wù)處理
DECLARE @Operater NVARCHAR(50),@Member_nbr INT
SELECT @Member_nbr = [Member_nbr] FROM inserted
SELECT @Operater = [Operater] FROM [#AuditWho] WHERE [PrimaryKey] = @Member_nbr
--插入Audit 表中
--INSERT INTO ....
END
GO
更新觸發(fā)器:
MemberTr_Update
CREATE TRIGGER [dbo].[MemberTr_Update]
ON [dbo].[Member]
FOR UPDATE
AS
BEGIN
IF @@ROWCOUNT = 0 RETURN
SET NOCOUNT ON
--事務(wù)處理
DECLARE @Operater NVARCHAR(50),@Member_nbr INT
SELECT @Member_nbr = [Member_nbr] FROM deleted
SELECT @Operater = [Operater] FROM [#AuditWho] WHERE [PrimaryKey] = @Member_nbr
--插入Audit 表中
--INSERT INTO ....
END
GO
刪除觸發(fā)器:
MemberTr_Delete
CREATE TRIGGER [dbo].[MemberTr_Delete]
ON [dbo].[Member]
FOR DELETE
AS
BEGIN
IF @@ROWCOUNT = 0 RETURN
SET NOCOUNT ON
--事務(wù)處理
DECLARE @Operater NVARCHAR(50),@Member_nbr INT
SELECT @Member_nbr = [Member_nbr] FROM deleted
SELECT @Operater = [Operater] FROM [#AuditWho] WHERE [PrimaryKey] = @Member_nbr
--插入Audit 表中
--INSERT INTO ....
END
GO
每段代碼,有注釋。
此問(wèn)題有在某論壇發(fā)表讓網(wǎng)友討論過(guò),但是效果不佳。如果你有另外見(jiàn)解,可以在討論。謝謝。
相關(guān)文章
Sql?Prompt?10下載與安裝破解圖文教程(最新推薦)
sql?prompt?10是一款擁有智能提示功能的SQL?Server和VS插件,,特別適合開(kāi)發(fā)者不大熟悉腳本時(shí)候使用,這篇文章主要介紹了Sql?Prompt?10下載與安裝破解圖文教程,需要的朋友可以參考下2023-03-03行轉(zhuǎn)列之SQL SERVER PIVOT與用法詳解
這篇文章主要給大家介紹了關(guān)于行轉(zhuǎn)列之SQL SERVER PIVOT與用法的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用SQL SERVER具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09SqlServer 序號(hào)列的實(shí)現(xiàn)方法
對(duì)于 SQL SERVER 2000 及更早的版本,需要使用一個(gè)自增列,結(jié)合臨時(shí)表來(lái)實(shí)現(xiàn)。2009-06-06SQL Server誤區(qū)30日談 第26天 SQL Server中存在真正的“事務(wù)嵌套”
嵌套事務(wù)可不會(huì)像其語(yǔ)法表現(xiàn)的那樣看起來(lái)允許事務(wù)嵌套。我真不知道為什么有人會(huì)這樣寫(xiě)代碼,我唯一能夠想到的就是某個(gè)哥們對(duì)SQL Server社區(qū)嗤之以鼻然后寫(xiě)了這樣的代碼說(shuō):“玩玩你們”2013-01-01CentOS 7.3上SQL Server vNext CTP 1.2安裝教程
這篇文章主要為大家詳細(xì)介紹了CentOS 7.3上SQL Server vNext CTP 1.2安裝教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01真正高效的SQLSERVER分頁(yè)查詢(xún)(多種方案)
Sqlserver數(shù)據(jù)庫(kù)分頁(yè)查詢(xún)一直是Sqlserver的短板,分頁(yè)查詢(xún)每頁(yè)30條,查詢(xún)第1500頁(yè)(即第45001-45030條數(shù)據(jù))進(jìn)行測(cè)試,分析出最高效的查詢(xún),感興趣的朋友可以參考下哈2013-04-04SQL Server一個(gè)字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個(gè)字符串
這篇文章介紹了SQL Server一個(gè)字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個(gè)字符串的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05sql?server多行數(shù)據(jù)合并一行顯示簡(jiǎn)單實(shí)現(xiàn)代碼
有時(shí)候我們需要將多行數(shù)據(jù)按照某一列進(jìn)行合并,以便更方便地進(jìn)行數(shù)據(jù)分析和處理,這篇文章主要給大家介紹了關(guān)于sql?server多行數(shù)據(jù)合并一行顯示簡(jiǎn)單實(shí)現(xiàn)的相關(guān)資料,需要的朋友可以參考下2023-12-12五種SQL Server分頁(yè)存儲(chǔ)過(guò)程的方法及性能比較
本文主要介紹了SQL Server數(shù)據(jù)庫(kù)分頁(yè)的存儲(chǔ)過(guò)程的五種方法以及它們之間性能的比較,并給出了詳細(xì)的代碼,希望能夠?qū)δ兴鶐椭?/div> 2015-08-08最新評(píng)論