Asp.net 数据库缓存依赖(SQLServer 2005)

1.       检测是否已经启用Service Broker 

Select DATABASEpRoPERTYEX('数据库名称','IsBrokerEnabled')  -- 1 表示已经启用 0 表示没有启用

2.       启用Service Broker

Alter database 数据库名称 set ENABLE_BROKER;

3. vs2005中启用数据库缓存依赖
aspnet_regsql.exe -S localhost -U sa -P sa -d database -ed

aspnet_regsql.exe -S localhost -U sa -P sa -d database -t table et

可以通过aspnet_regsql -?查看命令

4. Gload.asxm中配置

void Application_Start(object sender, EventArgs e)
    { //
在应用程序启动时运行的代码
       
System.Data.SqlClient.SqlDependency.Start(ConnectionString);
   
}
   
void Application_End(object sender, EventArgs e)
    {//
在应用程序关闭时运行的代码
       
System.Data.SqlClient.SqlDependency.Stop(ConnectionString);
    }

5. Web.config中配置(不是必须的)

<caching>
    <sqlCacheDependency enabled="true" pollTime="1000">
      <databases>  
      <add name="hnfms" connectionStringName="hnfmsConnectionString"/>
     </databases>
    </sqlCacheDependency>
   </caching>

6. 应用程序数据缓存中使用

SqlCommand cmd = new SqlCommand(sql,conn);                                   

SqlCacheDependency scd = new SqlCacheDependency(cmd); 说明:这条语句最好在cmd执行操作之前执行,如

SqlCacheDependency scd = new SqlCacheDependency(cmd); command.ExecuteReader();等语句前

Cache.Insert(...,scd,...);

   注意:

    a).      必须设置完全限定名称的数据表。即表名前面需要加所有者,如dbo.test。

    b).      必须明确设置所访问数据库列名称,不能使用*

    c).      必须保证不是聚合函数。如COUNT、MAX等。

7. 解决SqlServer启用数据表缓存信赖,非dbo构架的数据表注册不成功的问题

问题提示:

无法对触发器 'dbo.Production.Product_AspNet_SqlCacheNotification_Trigger' 执行创建,因为其架构不同于目标表或视图的架构。在缓存依赖项注册期间失败。

 请确保数据库名称和表名称有效。表名称必须符合 SQL 中规则标识符的格式。

 失败的 SQL 命令是: dbo.AspNet_SqlCacheRegisterTableStoredProcedure

方法:

1.打开当前数据库,在存储过程列表中找到名称为[dbo].[AspNet_SqlCacheRegisterTableStoredProcedure] 的存储过程并打开。

2.将该存储过程内容的 SET @fullTriggerName = 'dbo.[' + @triggerName + ']'  修改为 SET @fullTriggerName = '[dbo.' + @triggerName + ']'。

3.执行该存储过程,然后重新创建数据表的缓存依赖(执行3中的语句),创建成功!

参考:

http://www.cnblogs.com/mrhgw/archive/2008/09/20/1294656.html

http://hi.baidu.com/freesunshine/blog/item/5749e813ede7002bdc5401d0.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值