エンティティフレームワーク-ネイティブSQL
Entity Frameworkでは、LINQを使用してエンティティクラスでクエリを実行できます。DbCOntextを使用して、生のSQLを使用してデータベースに対して直接クエリを実行することもできます。この手法は、CodeFirstとEFDesignerで作成されたモデルにも同様に適用できます。
既存のエンティティに対する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クエリ
プリミティブ型を含む任意の型のインスタンスを返すSQLクエリは、DatabaseクラスのSqlQueryメソッドを使用して作成できます。例-
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メソッドは、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();
}
}
}
上記のコードは、データベースからすべての学生の名を取得します。