繁体   English   中英

将数据表的子集传递给SQL Server

[英]Pass subsets of datatable to SQL Server

我试图弄清楚如何分解我的数据表并将其(作为UDT)发送到sql server)。 因此,如果我的数据表中有100,000个数据,我希望能够将其分解为10,000个数据块,以向下发送到sql服务器。 我只是不确定如何将100,000的数据表分解为10,000k的数据块?

任何建议将不胜感激。

所以,如果我使用这样的东西:

var results = (from myRow in myDataTable.AsEnumerable()
              select myRow).take(10000);

不确定如何确保从数据表中获取下一组10,000行,并确保不发送重复项并获取所有行?

只需编写一个简单的方法即可将任何集合变成指定大小的块:

/// <summary>Splits a collection into chunks of equal size. The last chunk may be smaller than chunkSize, but all chunks, if any, will contain at least one element.</summary>
public static IEnumerable<IEnumerable<T>> Chunk<T>(this IEnumerable<T> source, int chunkSize)
{
    if (chunkSize <= 0)
        throw new ArgumentException("chunkSize must be greater than zero.", "chunkSize");
    return chunkIterator(source, chunkSize);
}
private static IEnumerable<IEnumerable<T>> chunkIterator<T>(IEnumerable<T> source, int chunkSize)
{
    var list = new List<T>();
    foreach (var elem in source)
    {
        list.Add(elem);
        if (list.Count == chunkSize)
        {
            yield return list;
            list = new List<T>();
        }
    }
    if (list.Count > 0)
        yield return list;
}

然后您可以简单地使用它,例如:

foreach (var chunk in myDataTable.AsEnumerable().Chunk(10000))
{
    // Process the chunk
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM