码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • .net core 使用异步等待(Async-await)在Foreach中提示“连接不支持 MultipleActiveResultSets”


    问题:

    使用数组集合的ForEach方法在Lambda中进行异步(Async)批量更新操作实体对象时,更新失败抛出错误:“The connection does not support MultipleActiveResultSets” 错误信息。

     代码片段:

    1. demand.Characters.ForEach(async type =>
    2. {
    3. var userCharacterDemand = new UserCharacterDemandEntity
    4. {
    5. Character = type,
    6. User = user
    7. };
    8. await Context.UserCharacterDemands.AddAsync(userCharacterDemand);
    9. });

    该代码为列表中的每个项目启动一个任务,但不会等待每个任务完成后再启动下一个任务。

    这相当于:

    1. foreach (var type in demand.Characters)
    2. {
    3. var userCharacterDemand = new UserCharacterDemandEntity
    4. {
    5. Character = type,
    6. User = user
    7. };
    8. Context.UserCharacterDemands.Add(userCharacterDemand);
    9. }

     

    原因:

    ForEach 不是一个异步方法。它不会等待由Lambda返回的Task。执行ForEach循环将触发每项任务时并不等待完成任何任务。

    问题要点:

    将一个Lambda标记为Async并不会使您传递给它的同步方法具有异步行为。

    解决方案一:(推荐)

    需要使用foreach循环,等待任务完成。

    例如:

    foreach(var x in xy) await f(x);

    1. foreach (var type in demand.Characters)
    2. {
    3. var userCharacterDemand = new UserCharacterDemandEntity
    4. {
    5. Character = type,
    6. User = user
    7. };
    8. await Context.UserCharacterDemands.AddAsync(userCharacterDemand);
    9. }

    解决方案二:

    需要在连接字符串中添加属性 MultipleActiveResultSets 并将其设置为 true,以允许多个活动结果集。

    详情查看官方说明:

    Enabling Multiple Active Result Sets - ADO.NET | Microsoft Docs

     

  • 相关阅读:
    【gogogo专栏】golang并发编程
    只需5分钟,完成Redis所有命令操作~
    21天学习挑战赛-线性表(下)
    项目管理软件dhtmlxGantt配置教程(七):如何自定义内联编辑器
    mysql索引最左前缀法则、使用场景
    day34
    User 10 must be unlocked for widgets to be available
    二面被 RocketMQ 虐后,狂刷这套实战到源码手册,再战阿里
    智能机器人:打造自动化未来的关键技术
    智慧水利整体解决方案
  • 原文地址:https://blog.csdn.net/LZD_jay/article/details/125549288
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号