在SQL触发器或存储过程中获取登录用户信息

数据库 SQL Server
本文详细介绍了怎样在SQL触发器或存储过程中获取程序登录用户信息的过程,希望能对读者有所帮助。

SQL触发器存储过程中,可以获取程序登录的用户。下面我们就开始介绍,怎样实现在SQL触发器或存储过程中获取在程序登录的用户。在插入,更新或删除的存储过程,把登录程序当前用户传入进去。在存储过程中,再把相关信息存入局部(#)临时表中,这样子,在触发器即可获取了。

下面代码示例,以一个[Member]表作例,可以参详:

  1. Member  
  2.  
  3. CREATE TABLE Member  
  4.  
  5. (  
  6.  
  7. Member_nbr INT IDENTITY(1,1) PRIMARY EKY NOT NULL,  
  8.  
  9. [Name] NVARCHAR(30),  
  10.  
  11. Birthday DATETIME,  
  12.  
  13. Email NVARCHAR(100),  
  14.  
  15. [Address] NVARCHAR(100)  
  16.  
  17. )  
  18.  
  19. GO 

插入存储过程:

  1. MemberSp_Insert  
  2.  
  3. CREATE PROCEDURE MemberSp_Insert  
  4.  
  5. (  
  6.  
  7. --Other parameter  
  8.  
  9. @Operater NVARCHAR(50) --带到此参数,可从程序的用户传至数据库  
  10.  
  11. )  
  12.  
  13. AS  
  14.  
  15. BEGIN 

处理插入事务:

  1. ---INSERT INTO [dbo].[Member] (xxx) VALUES(xxx) 

把相关信息存入临时表,方便在触发器时取到:

  1. IF OBJECT_ID('#AuditWho') IS NOT NULL  
  2.  
  3. DROP TABLE [#AuditWho]  
  4.  
  5. CREATE TABLE [#AuditWho] (PrimaryKey INT,Operater NVARCHAR(50))  
  6.  
  7. INSERT INTO [#AuditWho] VALUES(SCOPE_IDENTITY(),@Operater)  
  8.  
  9. END  
  10.  
  11. GO 

更新存储过程:

  1. MemberSp_Update  
  2.  
  3. CREATE PROCEDURE MemberSp_Update  
  4.  
  5. (  
  6.  
  7. --Other parameter  
  8.  
  9. @Member_nbr INT,  
  10.  
  11. @Operater NVARCHAR(50) --带到此参数,可从程序的用户传至数据库  
  12.  
  13. )  
  14.  
  15. AS  
  16.  
  17. BEGIN 

处理更新事务:

  1. ---UPDATE [dbo].[Member] SET [xxx] = xxx, ... WHERE [Member_nbr] = @Member_nbr 

把相关信息存入临时表,方便在触发器时取到:

  1. IF OBJECT_ID('#AuditWho') IS NOT NULL  
  2.  
  3. DROP TABLE [#AuditWho]  
  4.  
  5. CREATE TABLE [#AuditWho] (PrimaryKey INT,Operater NVARCHAR(50))  
  6.  
  7. INSERT INTO [#AuditWho] VALUES(@Member_nbr,@Operater)  
  8.  
  9. END  
  10.  
  11. GO 

删除存储过程:

  1. MemberSp_Delete  
  2.  
  3. CREATE PROCEDURE MemberSp_Delete  
  4.  
  5. (  
  6.  
  7. @Member_nbr INT,  
  8.  
  9. @Operater NVARCHAR(50) --带到此参数,可从程序的用户传至数据库  
  10.  
  11. )  
  12.  
  13. AS  
  14.  
  15. BEGIN 

处理删除事务:

  1. ---DELETE FROM [dbo].[Member] WHERE [Member_nbr] = @Member_nbr 

把相关信息存入临时表,方便在触发器时取到:

  1. IF OBJECT_ID('#AuditWho') IS NOT NULL  
  2.  
  3. DROP TABLE [#AuditWho]  
  4.  
  5. CREATE TABLE [#AuditWho] (PrimaryKey INT,Operater NVARCHAR(50))  
  6.  
  7. INSERT INTO [#AuditWho] VALUES(@Member_nbr,@Operater)  
  8.  
  9. END  
  10.  
  11. GO 

#p#

从上面的存储过程,用户相关的信息(应用程序的用户信息)已经在存储过程中存入临时表中,接下来,在触发器,怎样获取呢。可以参考下面的触发器代码:

插入触发器:

  1. MemberTr_Insert  
  2.  
  3. CREATE TRIGGER [dbo].[MemberTr_Insert]   
  4.  
  5. ON [dbo].[Member]  
  6.  
  7. FOR INSERT  
  8.  
  9. AS  
  10.  
  11. BEGIN  
  12.  
  13. IF @@ROWCOUNT = 0 RETURN  
  14.  
  15. SET NOCOUNT ON 

事务处理:

  1. DECLARE @Operater NVARCHAR(50),@Member_nbr INT  
  2.  
  3. SELECT @Member_nbr = [Member_nbr] FROM inserted  
  4.  
  5. SELECT @Operater = [Operater] FROM [#AuditWho] WHERE [PrimaryKey] = @Member_nbr 

插入Audit 表中:

  1. INSERT INTO ....  
  2.  
  3. END  
  4.  
  5. GO 

更新触发器:

  1. MemberTr_Update  
  2.  
  3. CREATE TRIGGER [dbo].[MemberTr_Update]   
  4.  
  5. ON [dbo].[Member]  
  6.  
  7. FOR UPDATE  
  8.  
  9. AS  
  10.  
  11. BEGIN  
  12.  
  13. IF @@ROWCOUNT = 0 RETURN  
  14.  
  15. SET NOCOUNT ON 

事务处理:

  1. DECLARE @Operater NVARCHAR(50),@Member_nbr INT  
  2.  
  3. SELECT @Member_nbr = [Member_nbr] FROM deleted  
  4.  
  5. SELECT @Operater = [Operater] FROM [#AuditWho] WHERE [PrimaryKey] = @Member_nbr 

插入Audit 表中:

  1. INSERT INTO ....  
  2.  
  3. END  
  4.  
  5. GO 

删除触发器:

  1. MemberTr_Delete  
  2.  
  3. CREATE TRIGGER [dbo].[MemberTr_Delete]   
  4.  
  5. ON [dbo].[Member]  
  6.  
  7. FOR DELETE  
  8.  
  9. AS  
  10.  
  11. BEGIN  
  12.  
  13. IF @@ROWCOUNT = 0 RETURN  
  14.  
  15. SET NOCOUNT ON 

事务处理:

  1. DECLARE @Operater NVARCHAR(50),@Member_nbr INT  
  2.  
  3. SELECT @Member_nbr = [Member_nbr] FROM deleted  
  4.  
  5. SELECT @Operater = [Operater] FROM [#AuditWho] WHERE [PrimaryKey] = @Member_nbr 

插入Audit 表中:

  1. INSERT INTO ....  
  2.  
  3. END  
  4.  
  5. GO 
按照以上的步骤操作就可以利用SQL触发器或存储过程来获得程序登录的用户了。本文就介绍到这里,希望能对各位有所帮助。

【编辑推荐】

  1. 误删SQL Server日志文件后怎样附加数据库
  2. SQL Server 2005数据库用户权限管理的设置
  3. 浅析SQL Server数据库专用管理员连接DAC的使用
  4. 在SQL SERVER 2005执行存储过程的权限分配问题
  5. T-SQL行列相互转换命令:PIVOT和UNPIVOT使用详解
责任编辑:赵鹏 来源: 博客园
相关推荐

2011-07-14 08:56:34

Sql Server

2010-05-26 17:57:44

MySQL 触发器

2011-03-03 09:30:24

downmoonsql登录触发器

2024-01-19 09:37:19

MySQL数据库

2010-07-16 10:19:31

2010-04-26 14:12:23

Oracle使用游标触

2011-03-28 10:05:57

sql触发器代码

2019-04-30 15:28:46

数据库存储过程触发器

2010-05-19 11:25:46

MySQL触发器

2010-11-12 09:18:13

SQL Server存

2009-12-24 17:52:05

WPF触发器

2011-08-15 15:56:31

SQL Server

2010-09-01 16:40:00

SQL删除触发器

2010-04-19 10:43:27

SQL Server

2010-10-19 15:31:40

sql server触

2010-09-13 17:03:34

sql server触

2009-04-07 13:56:03

SQL Server触发器实例

2011-05-20 14:06:25

Oracle触发器

2018-08-10 09:40:02

数据库MySQL存储过程

2010-04-09 09:07:43

Oracle游标触发器
点赞
收藏

51CTO技术栈公众号