实体框架 - Native SQL
在 Entity Framework 中,您可以使用 LINQ 查询实体类。您还可以使用 DbCOntext 直接对数据库使用原始 SQL 运行查询。这些技术同样适用于使用 Code First 和 EF Designer 创建的模型。
对现有实体执行 SQL 查询
DbSet 上的 SqlQuery 方法允许编写将返回实体实例的原始 SQL 查询。返回的对象将由上下文跟踪,就像它们由 LINQ 查询返回一样。例如 −
class Program { static void Main(string[] args) { using (var context = new UniContextEntities()) { var students = context.Students.SqlQuery("SELECT * FROM dbo.Student").ToList(); foreach (var student in students) { string name = student.FirstMidName + " " + student.LastName; Console.WriteLine("ID: {0}, Name: {1}, Enrollment Date {2} ", student.ID, name, student.EnrollmentDate.ToString()); } Console.ReadKey(); } } }
上述代码将从数据库中检索所有学生。
非实体类型的 SQL 查询
可以使用 Database 类上的 SqlQuery 方法创建返回任何类型(包括原始类型)实例的 SQL 查询。例如 −
class Program { static void Main(string[] args) { using (var context = new UniContextEntities()) { var studentNames = context.Database.SqlQuery <string>("SELECT FirstMidName FROM dbo.Student").ToList(); foreach (var student in studentNames) { Console.WriteLine("Name: {0}", student); } Console.ReadKey(); } } }
向数据库发送 SQL 命令
ExecuteSqlCommnad 方法用于向数据库发送非查询命令,例如插入、更新或删除命令。让我们看看以下代码,其中学生的名字更新为 ID = 1
class Program { static void Main(string[] args) { using (var context = new UniContextEntities()) { //Update command int noOfRowUpdated = context.Database.ExecuteSqlCommand("Update student set FirstMidName = 'Ali' where ID = 1"); context.SaveChanges(); var student = context.Students.SqlQuery("SELECT * FROM dbo.Student where ID = 1").Single(); string name = student.FirstMidName + " " + student.LastName; Console.WriteLine("ID: {0}, Name: {1}, Enrollment Date {2} ", student.ID, name, student.EnrollmentDate.ToString()); Console.ReadKey(); } } }
上述代码将从数据库中检索所有学生的名字。