我有使用.Net上下文的EF6框架控制台应用程序,我正在从中选择使用mehdime实体作用域,并试图在我的程序中获得结果的EF6查询。
我希望从WHERE中获得生成的SQL,但似乎找不到实现这一目标的方法(我的google很弱,而且我问错了问题)。
守则:
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类:
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:
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; }
}发布于 2020-06-11 11:42:50
可以使用ff从EF获取生成的查询:
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生成的查询。
https://stackoverflow.com/questions/62323529
复制相似问题