首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从Where表达式获取SQL查询

从Where表达式获取SQL查询
EN

Stack Overflow用户
提问于 2020-06-11 11:38:45
回答 1查看 131关注 0票数 0

我有使用.Net上下文的EF6框架控制台应用程序,我正在从中选择使用mehdime实体作用域,并试图在我的程序中获得结果的EF6查询。

我希望从WHERE中获得生成的SQL,但似乎找不到实现这一目标的方法(我的google很弱,而且我问错了问题)。

守则:

代码语言:javascript
复制
list<int> mailIds = new List<int>(); //list of ids that might be in db
using(var dbScope = Contexts.Scope.Create())
{
   var emails = Contexts.Mail.ResponseMail.Where(m => mailIds.Contains(m.Id));
   //I'd like to get the query resulting from this WHERE in a text format so that I can save it somewhere
   .....
}

Contexts.cs类:

代码语言:javascript
复制
using Mehdime.Entity;

....

class Contexts
{
    public static IDbContextScopeFactory Scope { get; } = new DbContextScopeFactory();
    private static IAmbientDbContextLocator Locator { get; } = new AmbientDbContextLocator();

    public static MailContext Mail => Locator.Get<MailContext>();
    ....
}

MailCotext.cs:

代码语言:javascript
复制
public class MailContext : DbContext
{
    public MailContext() : base(nameof(MailContext)) 
    {
        Database.SetInitializer(new CreateDatabaseAndSyncEnums<MailContext>());
    }

    protected override void OnModelCreating(DbModelBuilder modelBuilder)
    {
        modelBuilder.Conventions.Remove<PluralizingTableNameConvention>();
    }

    public DbSet<ResponseMessages> ResponseMail { get; set; }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-06-11 11:42:50

可以使用ff从EF获取生成的查询:

代码语言:javascript
复制
var emails = Contexts.Mail.ResponseMail.Where(m => mailIds.Contains(m.Id));
// using the IQueryable extract the query
var sql = ((System.Data.Entity.Core.Objects.ObjectQuery)emails)
            .ToTraceString();

您可以为此创建一个扩展,这样就可以很容易地获得从IQueryables生成的查询。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62323529

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档