C# 多线程同时执行一条查询SQL 有一些线程会查不到结果?

如题所述

当我们在程序中运用到多线程的时候,那么你必须要考虑的就是各线程抢占资源的问题,不能让同一时间多个线程去抢一个资源,比如你两个线程同时去操作sql,就会造成有脏读数据或者查不到数据,或者查的是脏数据,那么避免这个的办法可以从两边入手,C#程序里加入lock代码断,在里面执行查询sql,这样的话在再一时间,就不会有多个线程同时去执行sql,还可以在数据库中建立一些锁,执行的时候可将锁锁住,但对数据库加锁请小心 加锁和解锁,否则会锁死数据库造成系统崩溃都是有可能 的!
温馨提示:答案为网友推荐,仅供参考
第1个回答  2013-09-08
多线程操作,请确保每个线程操作的SQL语句中的表是相对独立的。
不然,你需要安排线程间的顺序,也就是lock代码段。
同一时间,两个线程一起跑同一句SQL,而且还操作同一张表,那么,肯定就会有问题了。本回答被网友采纳
第2个回答  2013-09-07
不会呀,数据库是支持多个现成同时读的,要不然别人网站怎么访问呢,你在请求,别人就访问不了了,读和写是不一样的哦。

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网