postgresql 创建listen notify .net core6.0监听连接

背景:数据库某张表定时有第三方更新到实时表里,收到数据更新以后,WEBSOCKET发送前端

-- 创建一个发送通知的函数

CREATE OR REPLACE FUNCTION notify_event(event_name text) RETURNS void AS $$

BEGIN

PERFORM pg_notify(event_name, '');

END;

LANGUAGE plpgsql; -- 创建一个触发器,在数据变化时调用通知函数 CREATE OR REPLACE FUNCTION notify_trigger() RETURNS trigger AS

BEGIN

PERFORM notify_event('data_changed');

RETURN NEW;

END;

LANGUAGE plpgsql; -- 在需要监听的表上创建触发器 CREATE TRIGGER data_change_trigger AFTER INSERT OR UPDATE OR DELETE ON river_area FOR EACH ROW EXECUTE FUNCTION notify_trigger(); .net core创建一个后台运行服务 using System; using System.Threading; using System.Threading.Tasks; using Microsoft.Extensions.Configuration; using Microsoft.Extensions.DependencyInjection; using Microsoft.Extensions.Hosting; using Npgsql; namespace Pipe.BLL { public class TableUpdateListenerService : BackgroundService { private readonly IServiceProvider _services; public TableUpdateListenerService(IServiceProvider services) { _services = services; } protected override async Task ExecuteAsync(CancellationToken stoppingToken) { using var scope = _services.CreateScope(); var serviceProvider = scope.ServiceProvider; var connectionString = serviceProvider.GetRequiredService\().GetConnectionString("LocalNpgsqlConnection"); using var conn = new NpgsqlConnection(connectionString); await conn.OpenAsync(stoppingToken); using var cmd = new NpgsqlCommand("listen data_changed", conn); cmd.ExecuteNonQuery(); conn.Notification += (sender, e) =\> { Console.WriteLine($"Received table update notification: {e.Payload}"); // 在这里执行相应的操作,处理接收到的通知 }; while (!stoppingToken.IsCancellationRequested) { using var transaction = conn.BeginTransaction(); await transaction.CommitAsync(); await Task.Delay(TimeSpan.FromSeconds(1), stoppingToken); // 可以选择适当的延迟时间 } } } } startup.cs注册下服务 services.AddHostedService\(); psql 发送测试。 UPDATE "public"."river_area" SET "objectid" = 5 WHERE "gid" = 3; NOTIFY data_changed, 'Your notification payload here'; 测试通过

相关推荐
zxrhhm1 天前
MySQL 8.4 LTS 数据库巡检脚本
数据库·mysql
AI木马人1 天前
9.【AI任务队列实战】如何在高并发下保证系统不崩?(Redis + Celery完整方案)
数据库·人工智能·redis·神经网络·缓存
2401_883600251 天前
golang如何理解weak pointer弱引用_golang weak pointer弱引用总结
jvm·数据库·python
aLTttY1 天前
【Redis实战】分布式锁的N种实现方案对比与避坑指南
数据库·redis·分布式
2301_773553621 天前
mysql如何评估SQL语句的索引开销_mysql性能追踪与分析
jvm·数据库·python
pele1 天前
PHP源码运行受主板供电影响吗_供电相数重要性说明【技巧】
jvm·数据库·python
sinat_383437361 天前
CSS如何实现元素悬浮在页面底部_利用fixed定位与底部间距
jvm·数据库·python
gmaajt1 天前
mysql如何备份与恢复函数定义_mysql mysqldump导出存储对象
jvm·数据库·python
阿丰资源1 天前
基于SpringBoot的在线视频教育平台的设计与实现(附源码+数据库+文档,一键运行)
数据库·spring boot·后端
qq_460978401 天前
Python爬虫怎么模拟手机端抓取_设置手机型号User-Agent字符串
jvm·数据库·python