ASP.NET Mvc開發(fā)之查詢數(shù)據(jù)
對(duì)于.NET平臺(tái)上開發(fā)WebForm項(xiàng)目,程序員操作數(shù)據(jù)的方法主要是通過使用ADO.NET。而我們MVC操作數(shù)據(jù)庫呢?與ADO.NET相比又有怎樣的優(yōu)勢(shì)呢?
一、大家都在談的EF到底是什么?
EF,全稱EntityFramWork。就是微軟以ADO.NET為基礎(chǔ)發(fā)展的所謂ORM(對(duì)象關(guān)系映射框架,或者說是數(shù)據(jù)持久化框架)。
簡(jiǎn)單的來說就是根據(jù)實(shí)體對(duì)象操作數(shù)據(jù)表中數(shù)據(jù)的一種面向?qū)ο蟮牟僮骺蚣?,具體的底層也是調(diào)用ADO.NET。
下面我們就來演示怎么使用EF來操作數(shù)據(jù)庫:
在數(shù)據(jù)庫關(guān)系圖中,表之間的關(guān)系是這樣的:

1)怎么創(chuàng)建實(shí)體對(duì)象模型文件
①創(chuàng)建基于ADO.NET的實(shí)體數(shù)據(jù)模型
我這里在我的Models文件夾(可以在任意地方哦)上“右鍵”→“新建項(xiàng)”,然后點(diǎn)擊進(jìn)入,在左側(cè)的模板中,選擇"數(shù)據(jù)",在右側(cè)就會(huì)看到“ADO.NET實(shí)體數(shù)據(jù)模型”的選項(xiàng),如下圖:

②點(diǎn)擊創(chuàng)建,進(jìn)入”實(shí)體數(shù)據(jù)模型向?qū)А埃@里我們可以選擇,要怎樣創(chuàng)建實(shí)體數(shù)據(jù)模型

注意:這里你可以分別選擇一種模型,在下邊的框中看到這兩種模型的區(qū)別,這里不多做解釋;
因?yàn)槲覀兪菑囊呀?jīng)有的數(shù)據(jù)庫創(chuàng)建實(shí)體模型,所以選擇第一種”從數(shù)據(jù)庫生成“
③點(diǎn)擊下一步,進(jìn)入連接數(shù)據(jù)庫的向?qū)?,通過新建連接,可以連接到自己的SQLServer服務(wù)器,然后選擇我們所要連接的數(shù)據(jù)庫,同時(shí)會(huì)生成實(shí)體連接字符串,如下圖:

④點(diǎn)擊下一步,選擇”實(shí)體框架版本“

⑤下一步,選擇需要在模型中包含的數(shù)據(jù)庫對(duì)象,選擇”確定所生成對(duì)象的單復(fù)數(shù)形式“,其它保持默認(rèn),點(diǎn)擊完成。如下圖:

這時(shí)會(huì)在我們的Models文件夾下邊生成一個(gè)edmx文件,同時(shí)EF框架的設(shè)計(jì)器幫我們生成了根據(jù)數(shù)據(jù)表關(guān)系生成的實(shí)體類的關(guān)系圖,如下圖:

注意:這里是不是發(fā)現(xiàn)這個(gè)表跟我們?cè)跀?shù)據(jù)庫關(guān)系圖中看到的圖有點(diǎn)相似啊?是的,很相似,但是所表達(dá)的意義是不一樣的。數(shù)據(jù)庫視圖所展示的是數(shù)據(jù)表之間的關(guān)系,而這里展示的EF幫我們根據(jù)數(shù)據(jù)表關(guān)系生成的實(shí)體類的關(guān)系;
2)生成的edmx文件到底是什么?
edmx文件的代碼樹如下:

①怎么會(huì)是XML文件?
我們通過”右鍵“→”打開方式“→在”XML編輯器“中打開,可以發(fā)現(xiàn)這個(gè)edmx文件是一個(gè)標(biāo)準(zhǔn)的XML文件,其中主要有三大塊,描述的就是我們的實(shí)體對(duì)象和數(shù)據(jù)庫映射的關(guān)系。如下圖:

②.tt文件下怎么生成了.cs文件?
數(shù)據(jù)庫上下文類。
在代碼樹中我們很容易的發(fā)現(xiàn),在.tt文件下邊生成了.cs類文件。”O(jiān)umindBlog.Context.cs“文件的代碼和作用如下:
//繼承自DbContext類,
//數(shù)據(jù)上下文類,用于操作數(shù)據(jù)庫。負(fù)責(zé)維護(hù)實(shí)體狀態(tài),以及根據(jù)實(shí)體對(duì)象包裝類的狀態(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; }
}
實(shí)體類。
而另一個(gè).tt文件生成的類是做什么用呢?我們打開一個(gè)看代碼:
//EF按照實(shí)體模型生成的實(shí)體類
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ù)庫中的字段是對(duì)應(yīng)的,這就是EF按照實(shí)體模型生成的實(shí)體類,而且在還成了外鍵屬性。
二、使用EF操作數(shù)據(jù)庫
在上面”O(jiān)umindBlog.Context.cs“中生成繼承DbContext的OumindBlogEntities 的類,來維護(hù)實(shí)體狀態(tài),并且操作數(shù)據(jù)庫,所以我們首先要?jiǎng)?chuàng)建該類的對(duì)象,并且操作數(shù)據(jù)的代碼如下:
//創(chuàng)建數(shù)據(jù)庫上下文類的對(duì)象
OumindBlogEntities db = new OumindBlogEntities();
#region 查詢文章列表+ActionResult Article()
/// <summary>
/// 查詢文章列表
/// </summary>
/// <returns></returns>
public ActionResult Article()
{
//通過db對(duì)象獲取文章列表
db.BlogArticles.Where(p => p.AIsDel == false);//使用Lamabda表達(dá)式來獲取為被刪除的文章
//使用Lamabda表達(dá)式來獲取數(shù)據(jù)
//返回一個(gè)List<T>的對(duì)象來存儲(chǔ)文章列表
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對(duì)象
ViewData["DataList"] = list;
return View();
}
#endregion
接著我們?yōu)锳rticle創(chuàng)建視圖,并且接收數(shù)據(jù),
因?yàn)槲覀冃枰褂肂logArticle對(duì)象來顯示數(shù)據(jù),所以應(yīng)該首先導(dǎo)入命名空間
<!------------首先導(dǎo)入命名空間------------->>
@using MvcApplication1.Models;
然后顯示數(shù)據(jù)的代碼是:
復(fù)制代碼
<!------------獲取數(shù)據(jù)并顯示html------------->>
<div>
<table id="tbList">
<tr>
<th>id</th>
<th>標(biāo)題</th>
<th>分類</th>
<th>狀態(tài)</th>
<th>時(shí)間</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>
運(yùn)行的結(jié)果如下:

三、總結(jié)
1)EF框架根據(jù)我們的數(shù)據(jù)庫中數(shù)據(jù)模型生成實(shí)體數(shù)據(jù)模型;
2)實(shí)體數(shù)據(jù)模型為一個(gè)edmx文件,且該文件為一個(gè)標(biāo)準(zhǔn)的XML文件,主要描述實(shí)體對(duì)象和數(shù)據(jù)庫映射關(guān)系;
3).tt文件為我們生成了數(shù)據(jù)庫上下文類(用于操作數(shù)據(jù)庫)和實(shí)體類(表示實(shí)體對(duì)象和外鍵屬性關(guān)系);
4)實(shí)體對(duì)象可以使用Lamabda表達(dá)式或者Linq來查詢需要的數(shù)據(jù),并且使用一個(gè)List對(duì)象來存儲(chǔ)數(shù)據(jù);
5)易于理解代碼,在實(shí)際的操作中不需要像ADO.net一樣創(chuàng)造大量的數(shù)據(jù)庫訪問層;
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助。
- asp.net mvc 從數(shù)據(jù)庫中讀取圖片的實(shí)現(xiàn)代碼
- asp.net mvc4 mysql制作簡(jiǎn)單分頁組件(部分視圖)
- 利用ASP.NET MVC+EasyUI+SqlServer搭建企業(yè)開發(fā)框架
- 使用jQuery向asp.net Mvc傳遞復(fù)雜json數(shù)據(jù)-ModelBinder篇
- ASP.NET MVC DropDownList數(shù)據(jù)綁定及使用詳解
- ASP.NET中MVC從后臺(tái)控制器傳遞數(shù)據(jù)到前臺(tái)視圖的方式
- Asp.net mvc 數(shù)據(jù)調(diào)用示例代碼
- ASP.NET MVC 數(shù)據(jù)驗(yàn)證及相關(guān)內(nèi)容
- ASP.NET Mvc開發(fā)之刪除修改數(shù)據(jù)
- ASP.NET中MVC傳遞數(shù)據(jù)的幾種形式總結(jié)
- JQuery對(duì)ASP.NET MVC數(shù)據(jù)進(jìn)行更新刪除
- asp.net實(shí)現(xiàn)的MVC跨數(shù)據(jù)庫多表聯(lián)合動(dòng)態(tài)條件查詢功能示例
- ASP.NET MVC使用EPPlus,導(dǎo)出數(shù)據(jù)到Excel中
相關(guān)文章
ASP.NET中UpdatePanel與jQuery同時(shí)使用所遇問題解決
在.NET中使用了UpdatePanel,里面的輸入框使用了jQuery的日歷選擇器,接下來介紹下兩者同時(shí)使用的一些細(xì)節(jié)及問題的解決方法,感興趣的各位可以參考下哈2013-03-03
ASP.NET?Core中Razor頁面與MVC區(qū)別介紹
這篇文章介紹了ASP.NET?Core中Razor頁面與MVC的區(qū)別,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02
詳解免費(fèi)開源的.NET多類型文件解壓縮組件SharpZipLib(.NET組件介紹之七)
本篇文章主要介紹了免費(fèi)開源的.NET多類型文件解壓縮組件SharpZipLib,這也是一種解壓縮組件,具有一定的參考價(jià)值,有興趣的可以了解一下。2016-12-12
asp.net頁面SqlCacheDependency緩存實(shí)例
這篇文章主要介紹了asp.net頁面SqlCacheDependency緩存實(shí)例,以一個(gè)完整實(shí)例來展現(xiàn)asp.net中緩存技術(shù)的使用方法,需要的朋友可以參考下2014-08-08
Asp.Net Core利用xUnit進(jìn)行主機(jī)級(jí)別的網(wǎng)絡(luò)集成測(cè)試詳解
這篇文章主要給大家介紹了關(guān)于Asp.Net Core利用xUnit進(jìn)行主機(jī)級(jí)別的網(wǎng)絡(luò)集成測(cè)試的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們來一起看看吧2018-12-12
使用VS2022在ASP.NET?Core中構(gòu)建輕量級(jí)服務(wù)
本文詳細(xì)講解了使用VS2022在ASP.NET?Core中構(gòu)建輕量級(jí)服務(wù)的方法,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-12-12
ASP.NET?Core中使用Redis實(shí)現(xiàn)緩存
本文詳細(xì)講解了ASP.NET?Core中使用Redis實(shí)現(xiàn)緩存的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03
詳解ASP.NET Core MVC 源碼學(xué)習(xí):Routing 路由
本篇文章主要介紹了詳解ASP.NET Core MVC 源碼學(xué)習(xí):Routing 路由 ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下。2017-03-03
asp.net DataGrid 中文字符排序的實(shí)現(xiàn)代碼
在論壇上看到有位朋友希望對(duì)中文按拼音進(jìn)行排序,剛好最近有點(diǎn)空,貼一份原來一個(gè)同事寫的一個(gè)排序類,僅稍微改動(dòng)了下下,拿出來分享下.2009-09-09

