Bootstrap

efcore调用函数_EFCore执行Sql语句的方法:FromSql与ExecuteSqlCommand

前言

在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)

;