
C# 多线程同时执行一条查询SQL 有一些线程会查不到结果? 15
展开全部
当我们在程序中运用到多线程的时候,那么你必须要考虑的就是各线程抢占资源的问题,不能让同一时间多个线程去抢一个资源,比如你两个线程同时去操作sql,就会造成有脏读数据或者查不到数据,或者查的是脏数据,那么避免这个的办法可以从两边入手,C#程序里加入lock代码断,在里面执行查询sql,这样的话在再一时间,就不会有多个线程同时去执行sql,还可以在数据库中建立一些锁,执行的时候可将锁锁住,但对数据库加锁请小心 加锁和解锁,否则会锁死数据库造成系统崩溃都是有可能 的!
展开全部
多线程操作,请确保每个线程操作的SQL语句中的表是相对独立的。
不然,你需要安排线程间的顺序,也就是lock代码段。
同一时间,两个线程一起跑同一句SQL,而且还操作同一张表,那么,肯定就会有问题了。
不然,你需要安排线程间的顺序,也就是lock代码段。
同一时间,两个线程一起跑同一句SQL,而且还操作同一张表,那么,肯定就会有问题了。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不会呀,数据库是支持多个现成同时读的,要不然别人网站怎么访问呢,你在请求,别人就访问不了了,读和写是不一样的哦。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询