开发手册 欢迎您!
软件开发者资料库

Entity Framework - 本机SQL

Entity Framework本机SQL - 从概述,体系结构,环境设置,数据库设置,数据模型,DbContext,类型,关系,生命周期,代码优先方法,模型优先方法,数据库第一方法,DEV方法,数据库操作,并发开始学习实体框架,事务,视图,索引,存储过程,断开连接的实体,表值函数,本机SQL,枚举支持,异步查询,持久性,投影查询,命令记录,命令拦截,空间数据类型,继承,迁移,渴望,懒惰,显式加载,验证,跟踪更改,彩色实体,第一个示例,数据注释,Fluent API,种子数据库,代码优先迁移,多个DbContext,嵌套实体类型。

在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}, \tEnrollment 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            ("SELECT FirstMidName FROM dbo.Student").ToList();         foreach (var student in studentNames) {            Console.WriteLine("Name: {0}", student);         }         Console.ReadKey();      }   }}

数据库的SQL命令

ExecuteSqlCommnad method用于向数据库发送非查询命令,例如Insert,Update或Delete命令.让我们来看看以下代码,其中学生的名字更新为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}, \tEnrollment Date {2} ",             student.ID, name, student.EnrollmentDate.ToString());         Console.ReadKey();      }   }}

以上代码将从数据库中检索所有学生的名字.