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();