[转]使用基于轮询的SQL数据缓存依赖

None.gif 当使用SQLSERVER2000中的SQL数据缓存依赖功能时,不得不采用轮询的机制检测特定数据库和数据库表中的数据是否发生更改。
None.gif
None.gif三个步骤:
None.gif
1 .需要使用aspnet_regsql命令行或者SqlCacheDepencyAdmmin类配置数据库。目的是启用数据库对SQL数据缓存依赖功能的支持。
None.gif
None.gifadpnet_regsql命令行的功能是完成有关数据库连接、应用服务、SQL数据缓存以来、会话状态等方面的配置。主要用来实现两项任务:
None.gif一是启用指定数据库的SQL数据库缓存依赖功能。aspnet_regsql 
- S ZGQ  - U sa  - P sa  - d pubs  - ed 
None.gif
None.gif二是启用指定表的SQL数据缓存依赖功能。aspnet_regsql 
- S ZGQ  - U sa  - P sa  - d pubs  - t titles  - et
None.gif 
None.gif这两项配置完成后在数据库中回新建一个名为“AspNet_SqlCacheTablesForChangeNotification”表。它是启用了指定数据库的数据缓存依赖后,自动创建的数据表。该表用于记录在数据库中,启用了数据缓存依赖的数据表数据被更新的概况信息。表中有三个数据列。列tableName用于存储被更新的数据表的名称,(这些表必须启用了SQL数据缓存依赖);列notifacationCreated是用于存储数据表被更新的时间;列changeid是每当所跟踪数据表的数据发生变化时,这个字段的值就加一。ASPNET将依靠changeid的数据来决定是继续使用缓存中的数据对象还是进行更新操作。另外在数据库中还增加了几个数据存储过程、角色、触发器等。这些都是SQL数据缓存依赖功能而自动生成的。
None.gif
None.gif获取当前数据库中启用SQL数据缓存以来功能的数据表列表。
None.gifaspnet_regsql 
- s ZGQ  - U sa  - P sa  - d pubs  - lt
None.gif
None.gif关闭数据库的数据缓存依赖功能
None.gifaspnet_regsql 
- s ZGQ  - U sa  - P sa  - d pubs  - dd
None.gif
None.gif关闭数据表的数据缓存依赖功能
None.gifaspnet_regsql 
- s ZGQ  - U sa  - P sa  - d pubs  - t titles  - dt 
None.gif
None.gif也可以使用SqlCacheDepencyAdmmin类配置数据库实现SQL缓存依赖功能
None.gif
None.gif建议在Global.ascx文件中使用SqlCacheDepencyAdmin类实现对SQL缓存依赖功能的统一管理:
None.gif
<% @ Application Language = " C# "   %>
None.gif
<% @ Import Namespace = " System.Configuration "   %>
None.gif
<% @ Import Namespace = " System.Web.Caching "   %>
None.gif
None.gif
< script runat = " server " >
None.gif
None.gif    
void  Application_Start( object  sender, EventArgs e) 
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
// 在应用程序启动时运行的代码
InBlock.gif        
//以下实现的是启用数据库和数据库表的缓存依赖功能
InBlock.gif        
//如果登陆用户不具有管理pubs数据库的权限,将发生异常
InBlock.gif        
//获取连接字符串
InBlock.gif
        string connectionString = ConfigurationManager.ConnectionStrings["SQLCONNECTIONSTRING"].ConnectionString;
InBlock.gif        
InBlock.gif        
//变量needToInstall指示是否需要起用数据缓存依赖功能
InBlock.gif
        bool needToInstall = true;
InBlock.gif        
try
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
//获取数据库中已经具有数据缓存依赖功能的数据表名称列表
InBlock.gif
            string[] tables = SqlCacheDependencyAdmin.GetTablesEnabledForNotifications(connectionString);
InBlock.gif
InBlock.gif            
if (tables != null)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
foreach (string table in tables)
ExpandedSubBlockStart.gifContractedSubBlock.gif                
dot.gif{
InBlock.gif                    
//如果已经包含准备设置缓存依赖的表,设置needToInstall值为false
InBlock.gif
                    if(table.ToLower().Equals("titles"))
ExpandedSubBlockStart.gifContractedSubBlock.gif                    
dot.gif{
InBlock.gif                        needToInstall 
= false;
InBlock.gif                        
ExpandedSubBlockEnd.gif                    }

ExpandedSubBlockEnd.gif                }

ExpandedSubBlockEnd.gif            }

InBlock.gif
ExpandedSubBlockEnd.gif        }

InBlock.gif        
catch (Exception ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            needToInstall 
= true;
InBlock.gif            
ExpandedSubBlockEnd.gif        }

InBlock.gif
InBlock.gif        
//如果变量needToInstall值为true,则启用数据库pubs和数据库表titles的缓存依赖功能。
InBlock.gif
        if (needToInstall)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            
try
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
//启用数据库pubs的数据缓存依赖功能
InBlock.gif
                SqlCacheDependencyAdmin.EnableNotifications(connectionString);
InBlock.gif                
InBlock.gif                
//启用数据库表titles的数据缓存依赖功能
InBlock.gif
                SqlCacheDependencyAdmin.DisableTableForNotifications(connectionString, "titles");
InBlock.gif
ExpandedSubBlockEnd.gif            }

InBlock.gif            
catch (Exception ex)
ExpandedSubBlockStart.gifContractedSubBlock.gif            
dot.gif{
InBlock.gif                
ExpandedSubBlockEnd.gif            }

InBlock.gif            
ExpandedSubBlockEnd.gif        }

InBlock.gif
ExpandedBlockEnd.gif    }

None.gif    
None.gif    
void  Application_End( object  sender, EventArgs e) 
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
//  在应用程序关闭时运行的代码
InBlock.gif

ExpandedBlockEnd.gif    }

None.gif        
None.gif    
void  Application_Error( object  sender, EventArgs e) 
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif
InBlock.gif        
// 在出现未处理的错误时运行的代码
InBlock.gif

ExpandedBlockEnd.gif    }

None.gif
None.gif    
void  Session_Start( object  sender, EventArgs e) 
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
// 在新会话启动时运行的代码
InBlock.gif

ExpandedBlockEnd.gif    }

None.gif
None.gif    
void  Session_End( object  sender, EventArgs e) 
ExpandedBlockStart.gifContractedBlock.gif    
dot.gif {
InBlock.gif        
// 在会话结束时运行的代码。 
InBlock.gif        
// 注意: 只有在 Web.config 文件中的 sessionstate 模式设置为
InBlock.gif        
// InProc 时,才会引发 Session_End 事件。如果会话模式设置为 StateServer 
InBlock.gif        
// 或 SQLServer,则不会引发该事件。
InBlock.gif

ExpandedBlockEnd.gif    }

None.gif       
None.gif
</ script >
None.gif
2 .配置Web.config文件
None.gif
None.gif
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值