加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – Database.SqlQuery线程安全

发布时间:2020-12-15 21:59:56 所属栏目:百科 来源:网络整理
导读:有没有人知道 Database.SqlQuery是否会做一些让线程不安全的事情(比如创建或招募交易等)? 这是我必须从多个线程调用的代码段 – 查询非常简单,硬编码(无法访问共享用户代码数据): public virtual long GetId(string sql){ var newid = DbContext.Database.
有没有人知道 Database.SqlQuery是否会做一些让线程不安全的事情(比如创建或招募交易等)?

这是我必须从多个线程调用的代码段 – 查询非常简单,硬编码(无法访问共享用户代码数据):

public virtual long GetId(string sql)
{
    var newid = DbContext.Database.SqlQuery<long>(sql).First();
    return newid;
}

我的目标是在次要发布期间通过 – 然后我们将有机会在需要时正确实现同步.

解决方法

由于ADO.NET使用 connection pooling并且创建一个相对较轻的新DbContext,因此可以安全地创建许多可在使用它们之后处理的上下文.

所以我会考虑在using块中创建一个新的DbContext,而不是使用field / property.

要回答您的第一个问题,运行像您的问题中的代码之类的查询将只执行针对数据库的语句,就像您使用旧式ADO.NET方式一样.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读