C# 在EF中直接運行SQL命令


相信不少使用EF的同志們已經知道如何在EF中運行SQL命令了。我在這里簡單總結下,希望對大家學習EF有所幫助!

在 EF第一個版本(.NET 3.5 SP1)中,我們只能通過將ObjectContext.Connection轉換為EntityConnection,再把 EntityConnection.StoreConnection轉換為SqlConnection。有了這個SqlConnection,我們再創建 SqlCommand便能順利運行SQL命令了。(個人覺得其實很煩,呵呵)

例如:

               EntityConnection entityConnection = (EntityConnection)ctx.Connection;
                DbConnection storeConnection = entityConnection.StoreConnection;
                DbCommand cmd = storeConnection.CreateCommand();
                cmd.CommandType = System.Data.CommandType.StoredProcedure;
               cmd.CommandText = "[PRO_USER_DIGITALCARD_CHECK]";

              。。。。。。。   

在EF4(.NET 4)中,我們有了全新的API:ObjectContext.ExecuteStoreCommand(...)和 ObjectContext.ExecuteStoreQuery<T>(...)。從函數名不難知道前者是為了執行某一並無返回集的SQL 命令,例如UPDATE,DELETE操作;后者是執行某一個查詢,並可以將返回集轉換為某一對象。
using (var ctx = new MyObjectContext())
{
    ctx.ExecuteStoreCommand("UPDATE Person SET Name = 'Michael' WHERE PersonID = 1");
}
復制代碼
using (var ctx = new MyObjectContext())
{
    var peopleViews = ctx.ExecuteStoreQuery<PersonView>("SELECT PersonID, Name FROM Person");
}

public class PersonView
{
    public int PersonID { get; set; }
    public string Name { get; set; }
}
復制代碼

現在有了EF4.1,API的名字又有了些許改變。如果說DbContext將ObjectContext做了包裝,那么DbContext.Database就是對應於數據庫端信息的封裝。執行SQL命令也自然從Database類型開始。對應於ExecuteStoreCommand和ExecuteStoreQuery<T>的是Database.ExecuteSqlCommand和Database.SqlQuery<T>using (var ctx = new MyDbContext())
{
    ctx.Database.ExecuteSqlCommand("UPDATE Person SET Name = 'Michael' WHERE PersonID = 1");
}
復制代碼

using (var ctx = new MyDbContext())
{
    var peopleViews = ctx.SqlQuery<PersonView>("SELECT PersonID, Name FROM Person").ToList();
}

public class PersonView
{
    public int PersonID { get; set; }
    public string Name { get; set; }

}

 

 

轉載:http://www.cnblogs.com/chengxiaohui/articles/2092001.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM