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<IConfiguration>().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<TableUpdateListenerService>();

psql 发送测试。

UPDATE "public"."river_area" SET "objectid" = 5 WHERE "gid" = 3;

NOTIFY data_changed, 'Your notification payload here'; 测试通过

相关推荐
jiayou644 小时前
KingbaseES 表级与列级加密完全指南
数据库·后端
GBASE1 天前
G术时刻 |GBase 8s数据库事务并发控制之封锁技术介绍(下)
数据库
xiezhr1 天前
逛GitHub发现了一款免费的带AI功能的数据库管理工具
数据库·ai编程·dba
吃糖的小孩2 天前
给 QQ AI 机器人设计“可控记忆”:会话摘要、手动长期记忆与角色卡边界
数据库
笃行3503 天前
金仓数据库数据安全双防线:静态存储加密与传输加密实战
数据库
笃行3503 天前
金仓数据库物理备份实战:sys_rman 全流程演练与误覆盖抢救
数据库
笃行3503 天前
金仓数据库逻辑备份实战:从全库导出到 Schema 替换的完整闭环
数据库
SelectDB4 天前
阶跃星辰基于 SelectDB 构建 PB 级 Agent 可观测平台
大数据·数据库·aigc
这个DBA有点耶4 天前
GROUP BY优化全解:如何写出既不丢数据又飞快的分组查询
数据库·mysql·架构