网站首页 全球最实用的IT互联网站!

人工智能P2P分享Wind搜索发布信息网站地图标签大全

当前位置:诺佳网 > 软件工程 > 后端开发 > .Net >

EFCore中巧妙利用ToQueryString()实现批插(不借助第

时间:2025-11-15 18:07

人气:

作者:admin

标签:

导读:dotnet10发布了,ef10也快发布了,但是还是只有批量更新(ExecuteUpdateAsync)和批量删除(ExecuteDeleteAsync)功能,没有批量插入。 今天给个办法,在不引用第三方库的情况下,巧妙利用ToQ...

dotnet10发布了,ef10也快发布了,但是还是只有批量更新(ExecuteUpdateAsync)和批量删除(ExecuteDeleteAsync)功能,没有批量插入。

今天给个办法,在不引用第三方库的情况下,巧妙利用ToQueryString()实现批插。
道理很简单,就是用efcore的ToQueryString()方法返回sql字符串,然后替换拼接实现insert into(...) select ... from ...

示例:

using var ctx = new MyDbContext();
var sql = ctx.Table1
    .AsSingleQuery()//防止开启分割查询导致生成的sql不正确
    .Select(e=>new {e.Id,e.Name})//这里new的字段就是需要插入的字符,根据需要添加
    .ToQueryString();
sql=sql.Replace("SELECT", "");
sql=sql.Substring(0,sql.IndexOf("FROM",StringComparison.OrdinalIgnoreCase));
var sql1 = ctx.Table2
    .AsSingleQuery()//防止开启分割查询导致生成的sql不正确
    .Select(e=>new {e.Id,e.Name+e.Field1})//这里的new是批量插入后面的select,字段里可以有运算符
    .ToQueryString();
sql=$"INSERT INTO({sql}) {sql1}";

await ctx.Database.ExecuteSqlRawAsync(sql);//执行生成批插语句

作者:Rick Carter
出处:http://pains.cnblogs.com/
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

温馨提示:以上内容整理于网络,仅供参考,如果对您有帮助,留下您的阅读感言吧!
相关阅读
本类排行
相关标签
本类推荐

CPU | 内存 | 硬盘 | 显卡 | 显示器 | 主板 | 电源 | 键鼠 | 网站地图

Copyright © 2025-2035 诺佳网 版权所有 备案号:赣ICP备2025066733号
本站资料均来源互联网收集整理,作品版权归作者所有,如果侵犯了您的版权,请跟我们联系。

关注微信