C#使用SqlDependency实现数据缓存

1、SqlDependency是什么:

  SqlDependency 对象表示应用程序和 SQL Server 实例间的查询通知依赖关系。应用程序可以创建一个 SqlDependency 对象并进行注册以通过OnChangeEventHandler 事件处理程序接收通知。

  它提供了这样一种能力:当被监测的数据库中的数据发生变化时,SqlDependency会自动触发OnChange事件来通知应用程序,从而达到让系统自动更新数据(或缓存)的目的。

  应用:数据实时性较高的场景、新闻、监控数据等。

  可以结合SignalR来实现web的实时数据更新。

2、使用方法:

  1)sql server设置:ALTER DATABASE <DatabaseName> SET ENABLE_BROKER;语句让相应的数据库启用监听服务,以便支持SqlDependency特性。

  2)代码:控制台项目,web项目推荐把start放在Application_start方法中。

  3)注意:查询语句中不能使用*,表名要加[dbo].[xx]。sql语句要执行。

 

conn =ConfigurationManager.ConnectionStrings["default"].ToString();
                //Start和Stop方法
                SqlDependency.Start(conn);
                Update(conn);
 private static void Update(string conn)
        {
            using (
                   SqlConnection connection =
                       new SqlConnection(conn))
            {
                //此处 要注意 不能使用*  表名要加[dbo]  否则会出现一直调用执行 OnChange
                string sql = "select agent from [dbo].[info]";
                
                using (SqlCommand command = new SqlCommand(sql, connection))
                {
                    connection.Open();
                    command.CommandType=CommandType.Text;
                    dependency = new SqlDependency(command);
                    dependency.OnChange += new OnChangeEventHandler(dependency_OnChange);
                    //必须要执行一下command
                    command.ExecuteNonQuery();
                    Console.WriteLine(dependency.HasChanges);
                }
            }
        }
        //update insert delete都会进入
        private static void dependency_OnChange(object sender, SqlNotificationEventArgs e)
        {
            Console.WriteLine("onchange方法中:"+dependency.HasChanges);
            Console.WriteLine("数据库数据发生变化"+DateTime.Now);
            //这里要再次调用
            Update(conn);
        }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,可以使用注解方式来实现缓存延迟双删。以下是一个简单的示例: 首先,我们需要使用一个缓存框架,比如Spring Cache,来管理缓存。 1. 引入Spring Cache依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-cache</artifactId> </dependency> ``` 2. 在启动类上添加@EnableCaching注解启用缓存功能: ```java @SpringBootApplication @EnableCaching public class YourApplication { public static void main(String[] args) { SpringApplication.run(YourApplication.class, args); } } ``` 3. 在需要进行缓存的方法上添加@Cacheable注解: ```java @Service public class YourService { @Cacheable(value = "yourCacheName", key = "#id") public YourData getDataById(Long id) { // 从数据库中获取数据的逻辑 return yourData; } } ``` 4. 在进行数据更新操作后,手动触发缓存的清除: ```java @Service public class YourService { @Autowired private CacheManager cacheManager; public void updateData(YourData data) { // 更新数据库中的数据的逻辑 // 清除缓存 Cache cache = cacheManager.getCache("yourCacheName"); if (cache != null) { cache.evict(data.getId()); } } } ``` 在这个示例中,@Cacheable注解用于标记需要进行缓存的方法,并指定了缓存的名称和键。当调用该方法时,如果缓存中存在对应的数据,则直接返回缓存数据;否则,会执行方法体中的逻辑,并将结果存入缓存。 在进行数据更新操作后,通过注入CacheManager对象,可以获取到指定的缓存,并使用evict方法手动清除缓存中的数据。 这样就实现了基于注解的缓存延迟双删。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值