C#拜求,局域网中A机器WINFORM程序更新了数据库的时候,B机器的WINFORM界面自动更新内容,要怎么样实现?
主要是我想在A机器更改了数据库的信息,B机器用来显示的。。我不知道如何实现。。求具体方法。。希望不要只发个socket,或者TIME。。触发器上来。。...
主要是我想在A机器更改了数据库的信息,B机器用来显示的。。我不知道如何实现。。求具体方法。。希望不要只发个socket,或者TIME。。触发器上来。。
展开
展开全部
如果你不希望用B机器去频繁的定时刷数据库的话,那我还是建议用UDP SOCKET来实现比较好,我之前做过一个活感觉跟你差不多。
流程是这样的,一台机器负责对数据库操作,10多个客户端需要同步数据。后来我的做法是,A机器执行完了数据库操作后,用UDP的方式往局域网类广播一个指令;其他机器监听某个端口,一旦接收到了该指令,就去读取一次数据库。
流程是这样的,一台机器负责对数据库操作,10多个客户端需要同步数据。后来我的做法是,A机器执行完了数据库操作后,用UDP的方式往局域网类广播一个指令;其他机器监听某个端口,一旦接收到了该指令,就去读取一次数据库。
更多追问追答
追问
请问UDP SOCKET。。需要用到SQL的储存过程来触发吗?提交的网络广播指令怎样存储?
追答
UDP是在客户端自己定义事件触发的,和存储过程没关系的。
比如你点了一个按钮,修改了数据库数据,修改完了之后,用UdpClinet对象网局域网里的某个端口广播一个指令,如"update".
其他机器的客户端程序启动的时候需要监听一下某端口,这样当A机器广播了一个指令之后,各个客户端就都会收到update这个指令,然后都去查询一下数据库更新一下显示结果就行了。
代码我现在没有,晚上回去我可以发上来给你看看。现在你可以去研究一下c# 的udpclient类
展开全部
只能在B机器后台刷新数据。有变化,就刷新显示界面
更多追问追答
追问
呵呵。您的意思是否跟Timer差不多?B机器不知道A什么时候提交过数据,所以它不知道什么时候去后台刷新数据哟。。还不如手动刷新减轻数据库的负担。。对吧?
追答
你的程序数据库访问量有多大? 没什么负担就这么来吧,还简单。
backgroundWorker_DoWork
while (true)
{
System.Threading.Thread.Sleep(5000);
//do
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
其实这个用socket比较好,
触发器的原理其实也是相当于一个线程监听,
time也是一个线程,原理一样
触发器的原理其实也是相当于一个线程监听,
time也是一个线程,原理一样
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询