[quote=引用 7 楼 -一个大坑 的回复:] ... 那么还是不是循环一条条插入?我用收费版的测试,速度的确快很多
... 那么还是不是循环一条条插入?我用收费版的测试,速度的确快很多
你上个帖子不是一种在纠结“跟踪”么 每条数据在一个context里都有“行状态跟踪”,所以你就别纠结了。 你无论加多少条,他的行状态都是added 其实也根本就不存在你说的,循环批次这种说法。因为对于EF来说,_dbContext.SaveChanges();永远都是 一批一批保存。 删掉行状态时delete的,添加行状态是add的,更新行状态是modified的
dbContext.Set<T>().AddRange(List1); _dbContext.Set<T>().AddRange(List2);
EntityFramework执行SaveChanges时,会默认包在一个ReadCommitted级别的事务中执行。 具体可参考(小心中文版非常糟糕): 【EntityFramework事务】 https://docs.microsoft.com/zh-cn/ef/ef6/saving/transactions 【Working with Transactions】 https://docs.microsoft.com/en-us/ef/ef6/saving/transactions
谁跟你说 AddRange 会不停开关数据库的?
[quote=引用 1 楼 正怒月神 的回复:] 你可以做事务呀, transactionscope
你可以做事务呀, transactionscope
62,046
社区成员
669,049
社区内容
加载中
.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。
希望和大家一起共同营造一个活跃、友好的社区氛围。
试试用AI创作助手写篇文章吧