C#泛型集合List分批操作(分批查询、写入等)

简单介绍两种方式

方式一:使用for循环,每次循环利用泛型集合的GetRange()方法,取一部分数据执行要执行的操作,例如:

var 
var range = 50;
int times = paramList.Count/range + (paramList.Count % range > 0 ? 1 :0 ); //paramList为要操作的数据,times为需要分批次数

for(int i = 0; i < times; i++)
{
    var tempParam = paramList.GetRange(i * range, (i + 1) * range > paramList.Count ?             (paramList.Count - i * range) : range);
    InsertToYourDatabase(tempParam);    //需要执行的方法
}

方式二:利用泛型集合的.Take()方法,Take()常与Skip()方法一起用于伪分页,这里用于分批操作也很方便,如下:

while(paramList.Count>0)
{
    var tempParam = paramList.Take(50).ToList();
    InsertToYourDatabase(tempParam );
    paramList.RemoveRange(0,tempParam .Count);
}

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C#泛型集合List是一种可以存储任意类型的动态数组,它位于System.Collections.Generic命名空间下。语法如下:List<T> listName = new List<T>(); 其中T代表泛型类型参数,可以是任意有效的C#数据类型。(引用) List集合可以通过add方法逐个添加元素,也可以使用AddRange方法将另一个List集合添加到当前集合中。例如,可以创建两个List<int>对象,一个用于存储偶数,一个用于存储奇数,然后将奇数集合添加到偶数集合中,并通过foreach循环遍历输出集合中的元素。代码如下(引用): ```csharp int[] nums = { 1, 2, 3, 4, 5, 6, 7, 8, 9 }; List<int> listEven = new List<int>(); List<int> listOdd = new List<int>(); foreach (int num in nums) { if (num % 2 == 0) { listEven.Add(num); } else { listOdd.Add(num); } } listEven.AddRange(listOdd); foreach (int item in listEven) { Console.Write(item + " "); } Console.ReadKey(); ``` 使用泛型集合List的一个好处是可以避免频繁的类型转换。通过指定泛型类型参数,我们可以直接在集合中存储特定类型的对象,而无需进行繁琐的类型转换。这样可以提高代码的可读性和效率。(引用)<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [C#List泛型用法,必知必会!](https://blog.csdn.net/qq_44034384/article/details/106312390)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [c#List泛型集合](https://blog.csdn.net/linxianming_/article/details/125979400)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值