C#下多线程更新数据库如何保持一致性
IIS部署的系统,会员有储值,消费等操作,如果多个客户端同时调用上述操作,如何保证不会产生错误数据。
目前我用加锁的方式 但是多客户端调用消费操作时,会等待,导致效率低下。
是否是因我使用锁的方式不合适,或是有其他的解决办法,多线程并发问题经验较少,望大家指教。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
多线程并发是一个比较大的问题,这里最简单的方案是采用数据库的事务一致性,将需要进行的操作包装在一个事务中构成一个原子操作。
日常使用中,加锁产生的影响完全看加锁区域的执行效率,具体的情况也需要根据实际的测量为准,一般情况下,最受影响的是数据库的执行效率。
Linq 的 DataContext 一次过解决 transaction, 脏读等问题。
还不用自己写一行代码。。
https://msdn.microsoft.com/en...