ASP.NET Mvc開發(fā)之查詢數(shù)據(jù)
對于.NET平臺上開發(fā)WebForm項目,程序員操作數(shù)據(jù)的方法主要是通過使用ADO.NET。而我們MVC操作數(shù)據(jù)庫呢?與ADO.NET相比又有怎樣的優(yōu)勢呢?
一、大家都在談的EF到底是什么?
EF,全稱EntityFramWork。就是微軟以ADO.NET為基礎(chǔ)發(fā)展的所謂ORM(對象關(guān)系映射框架,或者說是數(shù)據(jù)持久化框架)。
簡單的來說就是根據(jù)實體對象操作數(shù)據(jù)表中數(shù)據(jù)的一種面向?qū)ο蟮牟僮骺蚣?,具體的底層也是調(diào)用ADO.NET。
下面我們就來演示怎么使用EF來操作數(shù)據(jù)庫:
在數(shù)據(jù)庫關(guān)系圖中,表之間的關(guān)系是這樣的:
1)怎么創(chuàng)建實體對象模型文件
①創(chuàng)建基于ADO.NET的實體數(shù)據(jù)模型
我這里在我的Models文件夾(可以在任意地方哦)上“右鍵”→“新建項”,然后點擊進入,在左側(cè)的模板中,選擇"數(shù)據(jù)",在右側(cè)就會看到“ADO.NET實體數(shù)據(jù)模型”的選項,如下圖:
②點擊創(chuàng)建,進入”實體數(shù)據(jù)模型向?qū)А?,這里我們可以選擇,要怎樣創(chuàng)建實體數(shù)據(jù)模型
注意:這里你可以分別選擇一種模型,在下邊的框中看到這兩種模型的區(qū)別,這里不多做解釋;
因為我們是從已經(jīng)有的數(shù)據(jù)庫創(chuàng)建實體模型,所以選擇第一種”從數(shù)據(jù)庫生成“
③點擊下一步,進入連接數(shù)據(jù)庫的向?qū)?,通過新建連接,可以連接到自己的SQLServer服務(wù)器,然后選擇我們所要連接的數(shù)據(jù)庫,同時會生成實體連接字符串,如下圖:
④點擊下一步,選擇”實體框架版本“
⑤下一步,選擇需要在模型中包含的數(shù)據(jù)庫對象,選擇”確定所生成對象的單復數(shù)形式“,其它保持默認,點擊完成。如下圖:
這時會在我們的Models文件夾下邊生成一個edmx文件,同時EF框架的設(shè)計器幫我們生成了根據(jù)數(shù)據(jù)表關(guān)系生成的實體類的關(guān)系圖,如下圖:
注意:這里是不是發(fā)現(xiàn)這個表跟我們在數(shù)據(jù)庫關(guān)系圖中看到的圖有點相似???是的,很相似,但是所表達的意義是不一樣的。數(shù)據(jù)庫視圖所展示的是數(shù)據(jù)表之間的關(guān)系,而這里展示的EF幫我們根據(jù)數(shù)據(jù)表關(guān)系生成的實體類的關(guān)系;
2)生成的edmx文件到底是什么?
edmx文件的代碼樹如下:
①怎么會是XML文件?
我們通過”右鍵“→”打開方式“→在”XML編輯器“中打開,可以發(fā)現(xiàn)這個edmx文件是一個標準的XML文件,其中主要有三大塊,描述的就是我們的實體對象和數(shù)據(jù)庫映射的關(guān)系。如下圖:
②.tt文件下怎么生成了.cs文件?
數(shù)據(jù)庫上下文類。
在代碼樹中我們很容易的發(fā)現(xiàn),在.tt文件下邊生成了.cs類文件。”O(jiān)umindBlog.Context.cs“文件的代碼和作用如下:
//繼承自DbContext類, //數(shù)據(jù)上下文類,用于操作數(shù)據(jù)庫。負責維護實體狀態(tài),以及根據(jù)實體對象包裝類的狀態(tài)屬性,生成不同的SQL語句執(zhí)行 public partial class OumindBlogEntities : DbContext { public OumindBlogEntities() : base("name=OumindBlogEntities") { } protected override void OnModelCreating(DbModelBuilder modelBuilder) { throw new UnintentionalCodeFirstException(); } public DbSet<BlogArticle> BlogArticles { get; set; } public DbSet<BlogArticleCate> BlogArticleCates { get; set; } public DbSet<BlogUser> BlogUsers { get; set; } public DbSet<Enumeration> Enumerations { get; set; } }
實體類。
而另一個.tt文件生成的類是做什么用呢?我們打開一個看代碼:
//EF按照實體模型生成的實體類 public partial class BlogArticleCate { public BlogArticleCate() { this.BlogArticles = new HashSet<BlogArticle>(); } public int Id { get; set; } public int Author { get; set; } public string Name { get; set; } public string Remark { get; set; } public int Statu { get; set; } public bool IsDel { get; set; } public System.DateTime Addtime { get; set; } //生成的外鍵屬性 public virtual ICollection<BlogArticle> BlogArticles { get; set; } public virtual BlogUser BlogUser { get; set; } }
很容易的發(fā)現(xiàn)這些字段和我們數(shù)據(jù)庫中的字段是對應(yīng)的,這就是EF按照實體模型生成的實體類,而且在還成了外鍵屬性。
二、使用EF操作數(shù)據(jù)庫
在上面”O(jiān)umindBlog.Context.cs“中生成繼承DbContext的OumindBlogEntities 的類,來維護實體狀態(tài),并且操作數(shù)據(jù)庫,所以我們首先要創(chuàng)建該類的對象,并且操作數(shù)據(jù)的代碼如下:
//創(chuàng)建數(shù)據(jù)庫上下文類的對象 OumindBlogEntities db = new OumindBlogEntities(); #region 查詢文章列表+ActionResult Article() /// <summary> /// 查詢文章列表 /// </summary> /// <returns></returns> public ActionResult Article() { //通過db對象獲取文章列表 db.BlogArticles.Where(p => p.AIsDel == false);//使用Lamabda表達式來獲取為被刪除的文章 //使用Lamabda表達式來獲取數(shù)據(jù) //返回一個List<T>的對象來存儲文章列表 List < Models.BlogArticle > list= db.BlogArticles.Where(p => p.AIsDel == false).ToList(); //也可以使用Linq來獲取數(shù)據(jù) List<Models.BlogArticle> list1 = (from p in db.BlogArticles where p.AIsDel == false select p).ToList(); //使用ViewData來傳遞list對象 ViewData["DataList"] = list; return View(); } #endregion
接著我們?yōu)锳rticle創(chuàng)建視圖,并且接收數(shù)據(jù),
因為我們需要使用BlogArticle對象來顯示數(shù)據(jù),所以應(yīng)該首先導入命名空間
<!------------首先導入命名空間------------->> @using MvcApplication1.Models; 然后顯示數(shù)據(jù)的代碼是: 復制代碼 <!------------獲取數(shù)據(jù)并顯示html------------->> <div> <table id="tbList"> <tr> <th>id</th> <th>標題</th> <th>分類</th> <th>狀態(tài)</th> <th>時間</th> <th>操作</th> </tr> <!--遍歷 Action方法 設(shè)置給 ViewData 的集合數(shù)據(jù),生成HTML代碼--> @foreach (BlogArticle a in ViewData["DataList"] as List<BlogArticle>) { <tr> <td>@a.AId</td> <td>@a.ATitle</td> <td>@a.BlogArticleCate.Name</td> <td>@a.Enumeration.e_cname</td> <td>@a.AAddtime</td> </tr> } </table> </div>
運行的結(jié)果如下:
三、總結(jié)
1)EF框架根據(jù)我們的數(shù)據(jù)庫中數(shù)據(jù)模型生成實體數(shù)據(jù)模型;
2)實體數(shù)據(jù)模型為一個edmx文件,且該文件為一個標準的XML文件,主要描述實體對象和數(shù)據(jù)庫映射關(guān)系;
3).tt文件為我們生成了數(shù)據(jù)庫上下文類(用于操作數(shù)據(jù)庫)和實體類(表示實體對象和外鍵屬性關(guān)系);
4)實體對象可以使用Lamabda表達式或者Linq來查詢需要的數(shù)據(jù),并且使用一個List對象來存儲數(shù)據(jù);
5)易于理解代碼,在實際的操作中不需要像ADO.net一樣創(chuàng)造大量的數(shù)據(jù)庫訪問層;
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助。
- asp.net mvc 從數(shù)據(jù)庫中讀取圖片的實現(xiàn)代碼
- asp.net mvc4 mysql制作簡單分頁組件(部分視圖)
- 利用ASP.NET MVC+EasyUI+SqlServer搭建企業(yè)開發(fā)框架
- 使用jQuery向asp.net Mvc傳遞復雜json數(shù)據(jù)-ModelBinder篇
- ASP.NET MVC DropDownList數(shù)據(jù)綁定及使用詳解
- ASP.NET中MVC從后臺控制器傳遞數(shù)據(jù)到前臺視圖的方式
- Asp.net mvc 數(shù)據(jù)調(diào)用示例代碼
- ASP.NET MVC 數(shù)據(jù)驗證及相關(guān)內(nèi)容
- ASP.NET Mvc開發(fā)之刪除修改數(shù)據(jù)
- ASP.NET中MVC傳遞數(shù)據(jù)的幾種形式總結(jié)
- JQuery對ASP.NET MVC數(shù)據(jù)進行更新刪除
- asp.net實現(xiàn)的MVC跨數(shù)據(jù)庫多表聯(lián)合動態(tài)條件查詢功能示例
- ASP.NET MVC使用EPPlus,導出數(shù)據(jù)到Excel中
相關(guān)文章
ASP.NET MVC中jQuery與angularjs混合應(yīng)用傳參并綁定數(shù)據(jù)
這篇文章主要介紹了ASP.NET MVC中jQuery與angularjs混合應(yīng)用傳參并綁定數(shù)據(jù),需要的朋友可以參考下2017-06-06獲取遠程網(wǎng)頁的內(nèi)容之一(downmoon原創(chuàng))
獲取遠程網(wǎng)頁的內(nèi)容之一(downmoon原創(chuàng))...2007-03-03Entity?Framework?Core生成數(shù)據(jù)庫表
這篇文章介紹了Entity?Framework?Core生成數(shù)據(jù)庫表的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-03-03gridview checkbox從服務(wù)器端和客戶端兩個方面實現(xiàn)全選和反選
GridView中的checkbox的全選和反選在很多的地方都是要求實現(xiàn)的,所以下面就從服務(wù)器端和客戶端兩個方面實現(xiàn)了checkbox的選擇,感興趣的朋友可以了解下,希望本文對你有所幫助2013-01-01實現(xiàn)DataGridView控件中CheckBox列的使用實例
最近做WindowsForms程序,使用DataGridView控件時,加了一列做選擇用,發(fā)現(xiàn)CheckBox不能選中。搜索后,要實現(xiàn)DataGridView的CellContentClick事件,將代碼貼一下2014-01-01