详解SQL Server中DDL触发器和索引视图
创始人
2024-06-28 11:41:52
0

索引视图:

一般视图都虚表,即视图本身不存储数据,而且是一个查询,当访问视图时,SQL SERVER会自动根据视图的定义来访问基表数据。具有***的聚集索引的视图,

索引视图本身会存储数据,可以加快查询速度,但会增加数据修改的开销。所以索引视图适用的修改少而查询多的表。创建索引视图时,索引视图的***个索引

 

必须是CLUSTERED和UNIQUE。

索引视图的创建:

 

  1. CREATE TABLE dbo.t1  
  2. (  
  3. USERID VARCHAR(50),   
  4. USERNAME VARCHAR(256)  
  5. );  
  6. go  
  7. CREATE TABLE dbo.t2  
  8. (  
  9. USERID VARCHAR(50),   
  10. DepartID VARCHAR(50)  
  11. );  
  12. GO  
  13. CREATE TABLE dbo.t3  
  14. (  
  15. DepartID VARCHAR(50),   
  16. DepartName VARCHAR(256)  
  17. );  
  18. GO  
  19. CREATE VIEW dbo.USERINFO  
  20. WITH SCHEMABINDING  
  21. AS 
  22. SELECT a.USERID, a.USERNAME, c.DEPARTID, c.DEPARTNAME   
  23. FROM dbo.t1 a, dbo.t2 b, dbo.t3 c   
  24. WHERE a.USERID = b.USERID   
  25. AND b.DEPARTID = C.DEPARTID  
  26. GO  
  27. CREATE UNIQUE CLUSTERED INDEX IX_USERINFO_USERIDDEPARTID ON dbo.USERINFO(USERID, DEPARTID) 

SQL Server 中的DDL触发器

DDL触发器可以在整数据库范围内对对象的定义、修改、删除而触发执行的触发器。可以数据库级别对数据库对象进行控制和审记。或者服务器级别的触发器,如用户登录的审记。

DDL触发器事件定义:

  1.  
  2.     type 
  3.     date-time 
  4.     spid 
  5.     name 
  6.     name 
  7.     name 
  8.     name 
  9.     name 
  10.     name 
  11.     type 
  12.     command 
  13.  

 

 

DDL触发器的创建:

 

  1. CREATE TABLE dbo.t4  
  2. (  
  3. USERNAME VARCHAR(256),   
  4. TSQL VARCHAR(MAX),  
  5. CDATE DATETIME  
  6. );  
  7. GO  
  8. CREATE TRIGGER tr_dbDDL  
  9. ON DATABASE   
  10. FOR   
  11. DROP_TABLE, ALTER_TABLE, CREATE_TABLE,   
  12. CREATE_PROCEDURE, ALTER_PROCEDURE, DROP_PROCEDURE  
  13. AS 
  14. DECLARE @xdata XML;  
  15. SELECT @xdata  = EVENTDATA();  
  16. ROLLBACK;  
  17. INSERT INTO dbo.t4(USERNAME, TSQL, CDATE)  
  18. SELECT @xdata.value('(/EVENT_INSTANCE/UserName)[1]', 'nvarchar(max)') AS dbUserName,   
  19. @xdata.value('(/EVENT_INSTANCE/TSQLCommand)[1]', 'nvarchar(max)') AS T_SQL,   
  20. GETDATE() AS CDATE;  
  21.  
  22. GO  
  23. use master  
  24. go  
  25.  
  26. CREATE TABLE dbo.t5  
  27. (  
  28. USERNAME VARCHAR(256),   
  29. TSQL VARCHAR(MAX),  
  30. CDATE DATETIME  
  31. );  
  32. GO  
  33. ALTER TRIGGER tr_svrddl  
  34. ON ALL SERVER  
  35. FOR   
  36. CREATE_DATABASE, ALTER_DATABASE, DROP_DATABASE,   
  37. DDL_LOGIN_EVENTS   
  38. AS 
  39. DECLARE @xdata XML;  
  40. SELECT @xdata  = EVENTDATA();  
  41.  
  42.  
  43. INSERT INTO dbo.t4(USERNAME, TSQL, CDATE)  
  44. SELECT @xdata.value('(/EVENT_INSTANCE/LoginName)[1]', 'nvarchar(max)') AS dbUserName,   
  45. @xdata.value('(/EVENT_INSTANCE/TSQLCommand)[1]', 'nvarchar(max)') AS T_SQL,   
  46. GETDATE() AS CDATE;  
  47. GO 

 

【编辑推荐】

  1. SQL Server使用索引实现数据访问优化
  2. SQL Server数据库优化经验总结
  3. 如何使用SQLServer数据库查询累计值
  4. 浅析Oracle和SqlServer存储过程的调试、出错处理
  5. 几段SQLServer语句和存储过程
  6. 50种方法优化SQL Server数据库查询

 

相关内容

热门资讯

PHP新手之PHP入门 PHP是一种易于学习和使用的服务器端脚本语言。只需要很少的编程知识你就能使用PHP建立一个真正交互的...
网络中立的未来 网络中立性是什... 《牛津词典》中对“网络中立”的解释是“电信运营商应秉持的一种原则,即不考虑来源地提供所有内容和应用的...
各种千兆交换机的数据接口类型详... 千兆交换机有很多值得学习的地方,这里我们主要介绍各种千兆交换机的数据接口类型,作为局域网的主要连接设...
粉嫩如何诠释霸道 东芝M805... “霸道粉”是个什么玩意东芝M805拿过来的时候,笔者扑哧笑了,不是笑这款笔记本,而是笑这款产品的颜色...
什么是大数据安全 什么是大数据... 在《为什么需要大数据安全分析》一文中,我们已经阐述了一个重要观点,即:安全要素信息呈现出大数据的特征...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
全面诠释网络负载均衡 负载均衡的出现大大缓解了服务器的压力,更是有效的利用了资源,提高了效率。那么我们现在来说一下网络负载...
如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
30分钟搞定iOS自定义相机 最近公司的项目中用到了相机,由于不用系统的相机,UI给的相机切图,必须自定义才可以。就花时间简单研究...
Intel将Moblin社区控... 本周二,非营利机构Linux基金会宣布,他们将担负起Moblin社区的管理工作,而这之前,Mobli...