高性能数据导入方案一对多支持筛选- .NET SqlSugar ORM

一、数据导入有哪些难题

1、数据分类

   你需要将 插入、更新、忽略不计、错误数据 等进么分类汇总,最后返回给客户,如果没有很好的设计想把这些操作一步到位非常的难

2、高性能

   对于插入或者更新 肯定不能单纯的插入或者更新,一定要批量操作,或者用到blukcopy操作

3、数据验证

   对于错误数据要进行组装 ,并返回客户,让客户知道哪些字段 哪个数据出现错误

 

二、使用 Storageable 解决难题

我们可以使用SqlSugar ORM中的 Storageable功能来解决上面的几大难题 ,SqlSugar 作为老牌ORM框架一直在创新和更新

 

1、入门示例

如何用Storageable实现简单的插入或者更新

例题1:导入一个List ,当id等0插入, id>0执行更新 (id是主键 )

List<UinitBlukTable> list2 = new List<UinitBlukTable>(); list2.Add(new UinitBlukTable() { Id = 1, Name = "a", Create = DateTime.Now }); list2.Add(new UinitBlukTable() { Id = 2, Name = "a", Create = DateTime.Now }); list2.Add(new UinitBlukTable() { Id = 0, Name = "a", Create = DateTime.Now }); var x = Db.Storageable(list2) .SplitUpdate(it => it.Item.Id > 0) .SplitInsert(it => it.Item.Id == 0).ToStorage(); x.AsInsertable.ExecuteCommand(); x.AsUpdateable.ExecuteCommand();

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/zywjpf.html