欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在SQL觸發(fā)器或存儲過程中獲取在程序登錄的用戶

 更新時間:2012年01月20日 20:54:17   作者:  
每個用戶可以登錄系統(tǒng),在程序中操作數(shù)據(jù)(添加,更新和刪除)需要實現(xiàn)記錄操作跟蹤。是誰添加,更新和刪除的,這些信息將會插入至AuditLog表中
實現(xiàn)一個AuditLog的功能,是B/S結(jié)構(gòu)專案。

每個用戶可以登錄系統(tǒng),在程序中操作數(shù)據(jù)(添加,更新和刪除)需要實現(xiàn)記錄操作跟蹤。是誰添加,更新和刪除的,這些信息將會插入至AuditLog表中。
一般情況之下,在SQL的觸發(fā)器中,只能取到(SQL驗證sa;Windows驗證Domain\xxx)。這些用戶名,達(dá)不到效果,不能真正反映到是誰操作的。
下面是讓你清楚,怎樣實現(xiàn)在SQL觸發(fā)器或存儲過程中獲取在程序登錄的用戶,是在插入,更新或刪除的存儲過程,把登錄程序當(dāng)前用戶傳入進(jìn)去。在存儲過程中,再把相關(guān)信息存入局部(#)臨時表中,這樣子,在觸發(fā)器即可獲取了。

下面代碼示例,以一個[Member]表作例,可以參詳:
復(fù)制代碼 代碼如下:

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


插入存儲過程:
復(fù)制代碼 代碼如下:

MemberSp_Insert
CREATE PROCEDURE MemberSp_Insert
(
--Other parameter
@Operater NVARCHAR(50) --帶到此參數(shù),可從程序的用戶傳至數(shù)據(jù)庫
)
AS
BEGIN
--處理插入事務(wù)
---INSERT INTO [dbo].[Member] (xxx) VALUES(xxx)
--把相關(guān)信息存入臨時表,方便在觸發(fā)器時取到。
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


更新存儲過程:
復(fù)制代碼 代碼如下:

MemberSp_Update
CREATE PROCEDURE MemberSp_Update
(
--Other parameter
@Member_nbr INT,
@Operater NVARCHAR(50) --帶到此參數(shù),可從程序的用戶傳至數(shù)據(jù)庫
)
AS
BEGIN
--處理更新事務(wù)
---UPDATE [dbo].[Member] SET [xxx] = xxx, ... WHERE [Member_nbr] = @Member_nbr

--把相關(guān)信息存入臨時表,方便在觸發(fā)器時取到。
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

刪除存儲過程:
復(fù)制代碼 代碼如下:

MemberSp_Delete
CREATE PROCEDURE MemberSp_Delete
(
@Member_nbr INT,
@Operater NVARCHAR(50) --帶到此參數(shù),可從程序的用戶傳至數(shù)據(jù)庫
)
AS
BEGIN
--處理刪除事務(wù)
---DELETE FROM [dbo].[Member] WHERE [Member_nbr] = @Member_nbr

--把相關(guān)信息存入臨時表,方便在觸發(fā)器時取到。
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


從上面的存儲過程,用戶相關(guān)的信息(應(yīng)用程序的用戶信息)已經(jīng)在存儲過程中存入臨時表中,接下來,在觸發(fā)器,怎樣獲取呢。可以參考下面的觸發(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ā)器:
復(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ā)器:
復(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

每段代碼,有注釋。
此問題有在某論壇發(fā)表讓網(wǎng)友討論過,但是效果不佳。如果你有另外見解,可以在討論。謝謝。

相關(guān)文章

  • Sql?Prompt?10下載與安裝破解圖文教程(最新推薦)

    Sql?Prompt?10下載與安裝破解圖文教程(最新推薦)

    sql?prompt?10是一款擁有智能提示功能的SQL?Server和VS插件,,特別適合開發(fā)者不大熟悉腳本時候使用,這篇文章主要介紹了Sql?Prompt?10下載與安裝破解圖文教程,需要的朋友可以參考下
    2023-03-03
  • 行轉(zhuǎn)列之SQL SERVER PIVOT與用法詳解

    行轉(zhuǎn)列之SQL SERVER PIVOT與用法詳解

    這篇文章主要給大家介紹了關(guān)于行轉(zhuǎn)列之SQL SERVER PIVOT與用法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用SQL SERVER具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • SqlServer 序號列的實現(xiàn)方法

    SqlServer 序號列的實現(xiàn)方法

    對于 SQL SERVER 2000 及更早的版本,需要使用一個自增列,結(jié)合臨時表來實現(xiàn)。
    2009-06-06
  • SQL Server誤區(qū)30日談 第26天 SQL Server中存在真正的“事務(wù)嵌套”

    SQL Server誤區(qū)30日談 第26天 SQL Server中存在真正的“事務(wù)嵌套”

    嵌套事務(wù)可不會像其語法表現(xiàn)的那樣看起來允許事務(wù)嵌套。我真不知道為什么有人會這樣寫代碼,我唯一能夠想到的就是某個哥們對SQL Server社區(qū)嗤之以鼻然后寫了這樣的代碼說:“玩玩你們”
    2013-01-01
  • CentOS 7.3上SQL Server vNext CTP 1.2安裝教程

    CentOS 7.3上SQL Server vNext CTP 1.2安裝教程

    這篇文章主要為大家詳細(xì)介紹了CentOS 7.3上SQL Server vNext CTP 1.2安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • 真正高效的SQLSERVER分頁查詢(多種方案)

    真正高效的SQLSERVER分頁查詢(多種方案)

    Sqlserver數(shù)據(jù)庫分頁查詢一直是Sqlserver的短板,分頁查詢每頁30條,查詢第1500頁(即第45001-45030條數(shù)據(jù))進(jìn)行測試,分析出最高效的查詢,感興趣的朋友可以參考下哈
    2013-04-04
  • SQL Server一個字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個字符串

    SQL Server一個字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個字符串

    這篇文章介紹了SQL Server一個字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個字符串的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • sql?server多行數(shù)據(jù)合并一行顯示簡單實現(xiàn)代碼

    sql?server多行數(shù)據(jù)合并一行顯示簡單實現(xiàn)代碼

    有時候我們需要將多行數(shù)據(jù)按照某一列進(jìn)行合并,以便更方便地進(jìn)行數(shù)據(jù)分析和處理,這篇文章主要給大家介紹了關(guān)于sql?server多行數(shù)據(jù)合并一行顯示簡單實現(xiàn)的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • SQL Server 使用 Pivot 和 UnPivot 實現(xiàn)行列轉(zhuǎn)換的問題小結(jié)

    SQL Server 使用 Pivot 和 UnPivot 

    對于行列轉(zhuǎn)換的數(shù)據(jù),通常也就是在做報表的時候用的比較多,今天就通過本文給大家總結(jié)下SQL Server 使用 Pivot 和 UnPivot 實現(xiàn)行列轉(zhuǎn)換的問題小結(jié),感興趣的朋友一起看看吧
    2022-01-01
  • 五種SQL Server分頁存儲過程的方法及性能比較

    五種SQL Server分頁存儲過程的方法及性能比較

    本文主要介紹了SQL Server數(shù)據(jù)庫分頁的存儲過程的五種方法以及它們之間性能的比較,并給出了詳細(xì)的代碼,希望能夠?qū)δ兴鶐椭?/div> 2015-08-08

最新評論