ASP.NETMvc開發(fā)中查詢數(shù)據(jù)的示例分析-創(chuàng)新互聯(lián)

這篇文章將為大家詳細(xì)講解有關(guān)ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析,小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,希望大家閱讀完這篇文章后可以有所收獲。

創(chuàng)新互聯(lián)自2013年起,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站制作、成都網(wǎng)站建設(shè)網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元五原做網(wǎng)站,已為上家服務(wù),為五原各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18982081108

一、大家都在談的EF到底是什么?

EF,全稱EntityFramWork。就是微軟以ADO.NET為基礎(chǔ)發(fā)展的所謂ORM(對(duì)象關(guān)系映射框架,或者說是數(shù)據(jù)持久化框架)。

簡(jiǎn)單的來說就是根據(jù)實(shí)體對(duì)象操作數(shù)據(jù)表中數(shù)據(jù)的一種面向?qū)ο蟮牟僮骺蚣埽唧w的底層也是調(diào)用ADO.NET。

下面我們就來演示怎么使用EF來操作數(shù)據(jù)庫:

在數(shù)據(jù)庫關(guān)系圖中,表之間的關(guān)系是這樣的:

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

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),如下圖:

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

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

ASP.NET Mvc開發(fā)中查詢數(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í)體連接字符串,如下圖:

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

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

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

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

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

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

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

注意:這里是不是發(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文件的代碼樹如下:

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

①怎么會(huì)是XML文件?

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

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

 ②.tt文件下怎么生成了.cs文件?

數(shù)據(jù)庫上下文類。

在代碼樹中我們很容易的發(fā)現(xiàn),在.tt文件下邊生成了.cs類文件?!監(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é)果如下:

ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析

三、總結(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ù)庫訪問層;


關(guān)于“ASP.NET Mvc開發(fā)中查詢數(shù)據(jù)的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,使各位可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),請(qǐng)把它分享出去讓更多的人看到。

網(wǎng)頁名稱:ASP.NETMvc開發(fā)中查詢數(shù)據(jù)的示例分析-創(chuàng)新互聯(lián)
文章網(wǎng)址:http://www.muchs.cn/article44/cdshhe.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站制作App開發(fā)虛擬主機(jī)、外貿(mào)建站網(wǎng)站策劃、外貿(mào)網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)