前言
在EFCore中执行Sql语句的方法为:FromSql与ExecuteSqlCommand;在EF6中的为SqlQuery与ExecuteSqlCommand,而FromSql和SqlQuery有很大区别,FromSql返回值为IQueryable,因此为延迟加载的,可以与Linq扩展方法配合使用,但是有不少的坑(EFCore版本为1.1.0),直接执行Sql语句的建议不要使用FromSql,但是EFCore中并没有提供SqlQuery方法,因此下面会贴出SqlQuery的实现代码供大家参考,以便在EFCore中能使用。
FromSql和ExecuteSqlCommand的使用
测试时使用了SqlServer2008和SqlServer Profiler进行Sql语句捕捉,EFCore的版本为1.1.0。
测试的Entity Model与DbContext
public class MSSqlDBContext : DbContext
{
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseSqlServer(@"data source=localhost;initial catalog=TestDB;Integrated Security=True;");
}
public DbSet Person { get; set; }
public DbSet
Address { get; set; }}
[Table(nameof(Person))]
public class Person
{
public int id { get; set; }
public string name { get; set; }
[Column(TypeName = "datetime")]
public DateTime? birthday { get; set; }
public int? addrid { get; set; }
}
[Table(nameof(Address))]
public class Address
{
public int id { get; set; }
public string fullAddress { get; set; }
public double? lat { get; set; }
public double? lon { get; set; }
}
ExecuteSqlCommand
EFCore的ExecuteSqlCommand和EF6的一样,执行非查询的Sql语句:
var db = new MSSqlDBContext();
2 db.Database.ExecuteSqlCommand($"update {nameof(Person)