我有一个问题,停止每个循环的并行。停止Parallel.ForEach立即
我遍历了从表中检索到的大约40.000条DataRows的集合,当我的结果集中有100个条目时,我需要立即停止我的循环。问题是,当我在ParallelLoopState上触发Stop方法时,迭代不会立即停止,从而导致结果集中的不一致(对于少量或多个项目)。
我没有办法确定,只要我停下来,我杀死所有线程?
List<DataRow> rows = new List<DataRow>(dataTable.Select());
ConcurrentDictionary<string, object> resultSet = new ConcurrentDictionary<string, object>();
rows.EachParallel(delegate (DataRow row, ParallelLoopState state)
{
if (!state.IsStopped)
{
using (SqlConnection sqlConnection = new SqlConnection(Global.ConnStr))
{
sqlConnection.Open();
//{
// Do some processing.......
//}
var sourceKey = "key retrieved from processing";
if (!resultSet.ContainsKey(sourceKey))
{
object myCustomObj = new object();
resultSet.AddOrUpdate(
sourceKey,
myCustomObj,
(key, oldValue) => myCustomObj);
}
if (resultSet.Values.Count == 100)
state.Stop();
}
}
});
*为什么*你想要并行执行SQL命令?这不会使查询运行速度加快。你的*实际*问题是什么? –
在方法 –
中使用锁定BTW 40K行根本没有数据。当你只需要100个加载它们的所有40K时,虽然是一个错误。你为什么不使用'SELECT TOP 100'? –