首 页 | 精品电影 | 音乐天堂 | 在线游戏 | Flash MTV | 三湘书屋 | 幽默笑话 | 三湘图库 | 美女写真 | IT知识库 | QQ贴图 | 加入书签

网页制作网络编程图形图象操作系统冲浪宝典软件教学网络安全认证考试通信技术电子商务业内动态书籍教程原码

最近更新 文章分类 多媒体类 精品软件

本站搜索:
您的位置:三湘时空 -> IT知识库 -> 文章分类 -> 数据库技巧 -> .NET 2.0 SqlDependency快速上手指南
.NET 2.0 SqlDependency快速上手指南


文章类别:数据库技巧 来源: 作者: 发表日期:2006-8-3 字体:[ ]

小游戏 | 在线影院 | 幽默笑话 | 源码下载 | Flash MTV | 音乐试听 | 书屋 | 美女写真

此文以SQL Server 2005上实现为准,SQL Server 2000因为实现机制不同,请查阅相关资料。

 

       步骤一:在SQL Server 2005上执行ALTER DATABASE <DatabaseName> SET ENABLE_BROKER;语句让相应的数据库启用监听服务,以便支持SqlDependency特性。

       这条语句最好在数据库未执行任何事务的情况下执行。

 

       步骤二:调用SqlDependency.Start(String strConnectionString)方法,在应用程序端启用依赖监听器。

       该方法的参数为一个数据库的连接字符串,该数据库必须已经执行过步骤一的操作。

       对于同一连接字符串,若已经执行过该语句,再次执行不会发生任何异常,但返回值会为False.

       如果是在Web程序中使用,建议可以将该语句放在Application_Start事件中执行。

       监听是基于数据库的,而依赖才可以基于表或者查询。

 

       步骤三:该步骤分别有两种不同的做法。该阶段必须注意步骤。

              方法A:建立连接对象,再创建一个SqlCommand实例,创建SqlCacheDependency实例,在这步之后再调用Command对象来获取数据(这个顺序很重要)。之后调用Cache的Insert语句建立一个依赖于一个具体查询数据集的Cache项。

 

             SqlConnection conn = new SqlConnection(strConnection);

         SqlCommand command = new SqlCommand(strCommandText, conn);

         SqlCacheDependency dependency = new SqlCacheDependency(command);

        

         // 注册方法到委托,该委托是

         CacheItemRemovedCallback onRemove = new CacheItemRemovedCallback(RemovedCallback);

         // 新增或修改一条缓存记录

         Cache.Insert(strCacheKey, objAppCache, dependency, absoluteExpiration, slidingExpiration, CacheItemPriority.Default, onRemove);

 

          方法B:建立连接对象,再创建一个SqlCommand实例,最后创建SqlDependency实例。定义SqlDependency的委托OnChange,当数据发生改变时做出相应的处理(比如清除Cache)。

              SqlConnection conn = new SqlConnection(strConnection);

         SqlCommand command = new SqlCommand(strCommandText, conn);

         SqlCacheDependency dependency = new SqlCacheDependency(command);

             

              dependency.OnChange += new OnChangeEventHandler(Dependency_OnChange);

 

 

     注意事项:

       不知道是不是还存在BUG,我在项目开发中遇到一些奇怪的现象。同样的代码,在有的机器上运行则能捕捉到变化,有的则完全没反应;也有时会出现Cache刚建立就反复发生依赖改变的事件。偶尔Cache还会数据发生变化却不引发事件。

       但从最终项目实施的情况看,似乎都只是某些机器环境造成的不确定因素?这个无法确定。不过起码数据库端是否正常启用,可以通过SQL Server Profiler来查看监视。

http://www.cnblogs.com/Xrinehart/archive/2006/07/27/461106.html

上一篇:小议优化ASP.NET应用性能之Cache篇 下一篇:Q-Zone鼠标指针免费用
本栏目热门文章
·Windows XP下安装SQL2000企业版 2005-10-4
·在SQL Server 2000里设置和使用数据库复制 2005-11-13
·SQL SERVER实用技巧 2005-11-3
·SQL Server 数据库管理常用的SQL和T-SQL语句 2005-11-13
·配置SQL Server 2000选项 2005-10-8
·SQL中通配符、转义符与"["号的使用(downmoon) 2005-11-3
·如何使Microsoft SQL Server的日志文件不会增大? 2005-10-4
·Sql Server下数据库链接的使用方法 2005-11-21
·如何快速杀死占用过多资源(CPU,内存)的数据库进程 2005-11-13
·使用SQL Server导入和索引 Microsoft Word 文 2005-10-4
新近更新文章
·.NET 2.0 SqlDependency快速上手指南 2006-8-3
·利用同义词简化SQL Server 2005开发 2006-7-25
·让SQL Server为工作负载高峰提前做好准备 2006-7-25
·将SQLServer2005 数据库还原或恢复到SQLServer2 2006-7-20
·使用SQL Server 2005中的CLR集成 2006-7-14
·解决sqlserver2005中文版与vs2005的WebAppli 2006-7-14
·SQL server 2005的简单分页程序 2006-7-14
·SQL Server 数据库连接字符串的声明 2006-7-14
·SQL server 2005中的DATENAME函数 2006-7-14
·ORACLE8I转换数据到SQL SERVER 2006-7-10
首 页 | 软件发布 | 广告联系 | 下载帮助 | 意见反馈 | 网站地图
  CopyRight? 2002-2004 WWW.SXSKY.NET? All Rights Reserved
三湘时空 站长QQ:82675303 Email: