繁体   English   中英

如何通过C#监视Postgresql数据库表中的任何更改

[英]How to monitor postgresql database table for any changes via c#

我正在运行Windows服务,该服务从PostgreSQL的表中读取配置。 这些设置在服务启动时只能读取一次,并且对它们的任何更改都需要重新启动服务。 我在C#中寻找一种机制来监视数据库上的任何更改。 这样我便可以取回有关数据库更改的设置。

我一直在寻找的一种方法是从PostgreSQL触发器写入/修改文本文件,然后使用FileWatcher更新设置。 但是那里也没有成功。

首先,通过参考npgsql文档,使用命令listen <channel_name>创建了永久监听连接

然后我写了一个可以触发命令的触发器

PERFORM pg_notify('<channel_name>', format('Changed: %s ', NEW.column_name));

因此,触发器将捕获特定数据库表上的任何更改,然后触发器将通知发送到通道,并监听并处理C#代码

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM