📅  最后修改于: 2020-11-21 07:23:16             🧑  作者: Mango
在实体框架中,您可以使用LINQ查询实体类。您还可以使用原始SQL通过DbCOntext直接对数据库运行查询。可以将这些技术同等地应用于使用Code First和EF Designer创建的模型。
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();
}
}
}
上面的代码将从数据库中检索所有学生。
可以使用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();
}
}
}
ExecuteSqlCommnad方法用于向数据库发送非查询命令,例如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();
}
}
}
上面的代码将从数据库中检索所有学生的名字。