C#下多线程更新数据库如何保持一致性

IIS部署的系统,会员有储值,消费等操作,如果多个客户端同时调用上述操作,如何保证不会产生错误数据。

目前我用加锁的方式 但是多客户端调用消费操作时,会等待,导致效率低下。

是否是因我使用锁的方式不合适,或是有其他的解决办法,多线程并发问题经验较少,望大家指教。

阅读 7k
2 个回答

多线程并发是一个比较大的问题,这里最简单的方案是采用数据库的事务一致性,将需要进行的操作包装在一个事务中构成一个原子操作。
日常使用中,加锁产生的影响完全看加锁区域的执行效率,具体的情况也需要根据实际的测量为准,一般情况下,最受影响的是数据库的执行效率。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进