亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

ASP.NET Mvc開發之查詢數據

2024-07-10 13:29:54
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了ASP.NET Mvc開發之查詢數據的相關資料,感興趣的小伙伴們可以參考一下
 

對于.NET平臺上開發WebForm項目,程序員操作數據的方法主要是通過使用ADO.NET。而我們MVC操作數據庫呢?與ADO.NET相比又有怎樣的優勢呢?

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

EF,全稱EntityFramWork。就是微軟以ADO.NET為基礎發展的所謂ORM(對象關系映射框架,或者說是數據持久化框架)。

簡單的來說就是根據實體對象操作數據表中數據的一種面向對象的操作框架,具體的底層也是調用ADO.NET。

下面我們就來演示怎么使用EF來操作數據庫:

在數據庫關系圖中,表之間的關系是這樣的:

ASP.NET Mvc開發之查詢數據

1)怎么創建實體對象模型文件

①創建基于ADO.NET的實體數據模型

我這里在我的Models文件夾(可以在任意地方哦)上“右鍵”→“新建項”,然后點擊進入,在左側的模板中,選擇"數據",在右側就會看到“ADO.NET實體數據模型”的選項,如下圖:

ASP.NET Mvc開發之查詢數據

 

②點擊創建,進入”實體數據模型向導“,這里我們可以選擇,要怎樣創建實體數據模型

ASP.NET Mvc開發之查詢數據

注意:這里你可以分別選擇一種模型,在下邊的框中看到這兩種模型的區別,這里不多做解釋;

因為我們是從已經有的數據庫創建實體模型,所以選擇第一種”從數據庫生成“

③點擊下一步,進入連接數據庫的向導,通過新建連接,可以連接到自己的SQLServer服務器,然后選擇我們所要連接的數據庫,同時會生成實體連接字符串,如下圖:

ASP.NET Mvc開發之查詢數據

④點擊下一步,選擇”實體框架版本“

ASP.NET Mvc開發之查詢數據

⑤下一步,選擇需要在模型中包含的數據庫對象,選擇”確定所生成對象的單復數形式“,其它保持默認,點擊完成。如下圖:

ASP.NET Mvc開發之查詢數據

這時會在我們的Models文件夾下邊生成一個edmx文件,同時EF框架的設計器幫我們生成了根據數據表關系生成的實體類的關系圖,如下圖:

ASP.NET Mvc開發之查詢數據

注意:這里是不是發現這個表跟我們在數據庫關系圖中看到的圖有點相似???是的,很相似,但是所表達的意義是不一樣的。數據庫視圖所展示的是數據表之間的關系,而這里展示的EF幫我們根據數據表關系生成的實體類的關系;

2)生成的edmx文件到底是什么?

edmx文件的代碼樹如下:

ASP.NET Mvc開發之查詢數據

①怎么會是XML文件?

我們通過”右鍵“→”打開方式“→在”XML編輯器“中打開,可以發現這個edmx文件是一個標準的XML文件,其中主要有三大塊,描述的就是我們的實體對象和數據庫映射的關系。如下圖:

ASP.NET Mvc開發之查詢數據

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

  數據庫上下文類。

  在代碼樹中我們很容易的發現,在.tt文件下邊生成了.cs類文件。”OumindBlog.Context.cs“文件的代碼和作用如下:

 //繼承自DbContext類,  //數據上下文類,用于操作數據庫。負責維護實體狀態,以及根據實體對象包裝類的狀態屬性,生成不同的SQL語句執行  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; }  }

很容易的發現這些字段和我們數據庫中的字段是對應的,這就是EF按照實體模型生成的實體類,而且在還成了外鍵屬性。

二、使用EF操作數據庫

在上面”OumindBlog.Context.cs“中生成繼承DbContext的OumindBlogEntities 的類,來維護實體狀態,并且操作數據庫,所以我們首先要創建該類的對象,并且操作數據的代碼如下:

 

//創建數據庫上下文類的對象    OumindBlogEntities db = new OumindBlogEntities();    #region 查詢文章列表+ActionResult Article()    /// <summary>    /// 查詢文章列表    /// </summary>    /// <returns></returns>    public ActionResult Article()    {      //通過db對象獲取文章列表      db.BlogArticles.Where(p => p.AIsDel == false);//使用Lamabda表達式來獲取為被刪除的文章            //使用Lamabda表達式來獲取數據      //返回一個List<T>的對象來存儲文章列表      List < Models.BlogArticle > list= db.BlogArticles.Where(p => p.AIsDel == false).ToList();                  //也可以使用Linq來獲取數據       List<Models.BlogArticle> list1 = (from p in db.BlogArticles where p.AIsDel == false select p).ToList();      //使用ViewData來傳遞list對象      ViewData["DataList"] = list;      return View();    }     #endregion

接著我們為Article創建視圖,并且接收數據,
因為我們需要使用BlogArticle對象來顯示數據,所以應該首先導入命名空間

 

<!------------首先導入命名空間------------->>@using MvcApplication1.Models; 然后顯示數據的代碼是:復制代碼 <!------------獲取數據并顯示html------------->>  <div>    <table id="tbList">      <tr>        <th>id</th>        <th>標題</th>        <th>分類</th>        <th>狀態</th>        <th>時間</th>        <th>操作</th>      </tr>      <!--遍歷 Action方法 設置給 ViewData 的集合數據,生成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>

運行的結果如下:

ASP.NET Mvc開發之查詢數據

三、總結

1)EF框架根據我們的數據庫中數據模型生成實體數據模型;

2)實體數據模型為一個edmx文件,且該文件為一個標準的XML文件,主要描述實體對象和數據庫映射關系;

3).tt文件為我們生成了數據庫上下文類(用于操作數據庫)和實體類(表示實體對象和外鍵屬性關系);

4)實體對象可以使用Lamabda表達式或者Linq來查詢需要的數據,并且使用一個List對象來存儲數據;

5)易于理解代碼,在實際的操作中不需要像ADO.net一樣創造大量的數據庫訪問層;

以上就是本文的全部內容,希望對大家的學習有所幫助。



注:相關教程知識閱讀請移步到ASP.NET教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美性猛xxx| 日本一区二区三区四区视频| 久久久久99精品久久久久| 日韩亚洲成人av在线| 亚洲成人免费网站| 精品久久久国产| 国产精品自产拍高潮在线观看| 国产区精品在线观看| 久久精品中文字幕| 欧美亚洲成人免费| 国产精品十八以下禁看| 麻豆精品精华液| 欧美中文字幕在线视频| 久久亚洲精品中文字幕冲田杏梨| 久久综合九色九九| 中文字幕亚洲综合久久筱田步美| 91大神福利视频在线| 尤物99国产成人精品视频| 久久精品99久久久久久久久| 亚洲二区在线播放视频| 亚洲欧洲日产国产网站| 亚洲最大福利网站| 日韩精品在线视频美女| 亚洲免费视频在线观看| 国产精品日韩在线播放| 日韩免费av片在线观看| 欧美做受高潮1| 日韩在线视频播放| 91免费精品国偷自产在线| 久久久精品国产| 亚洲深夜福利在线| 亚洲成人网在线| 91po在线观看91精品国产性色| 97在线视频免费看| 国产成人精品电影久久久| 亚洲欧美精品在线| 国产一区红桃视频| 久久99国产精品久久久久久久久| 欧美精品成人在线| 成人亚洲综合色就1024| 亚洲精品国精品久久99热| 亚洲在线观看视频网站| 亚洲国产精品久久久| 国产日韩视频在线观看| 亚洲精品国偷自产在线99热| 亚洲精品成a人在线观看| 亚洲石原莉奈一区二区在线观看| 日韩欧美成人网| 国产精品一区二区三区久久久| 国产91精品不卡视频| 欧美激情在线观看| 91久久国产婷婷一区二区| 国产91色在线| 亚洲精品中文字幕女同| 欧美—级a级欧美特级ar全黄| 亚洲一区二区三区乱码aⅴ| 日韩中文av在线| 日韩va亚洲va欧洲va国产| 国模私拍视频一区| 亚洲另类xxxx| 欧美性资源免费| 亚洲精品国产拍免费91在线| xxxxx成人.com| 国产美女91呻吟求| 日韩欧美极品在线观看| 尤物九九久久国产精品的分类| 超碰97人人做人人爱少妇| 欧美多人爱爱视频网站| 69国产精品成人在线播放| 国产午夜精品一区二区三区| 国外成人在线播放| 国产精品福利片| 俺去了亚洲欧美日韩| 精品久久久999| 91精品国产综合久久香蕉| 国产成人小视频在线观看| 色婷婷av一区二区三区久久| 欧美日韩黄色大片| 久久久国产精品一区| 九九精品视频在线| 最新的欧美黄色| 97在线视频观看| 91精品久久久久久久久中文字幕| 国产丝袜一区视频在线观看| 亚洲一区二区中文字幕| 精品美女国产在线| 亚洲激情视频在线播放| 亚洲精品资源美女情侣酒店| 欧美成人精品一区| 欧美高清自拍一区| 欧美精品日韩www.p站| 成人黄色片在线| 国产精品麻豆va在线播放| 欧美视频在线免费| 91九色单男在线观看| 久久精品一区中文字幕| 国产欧美一区二区白浆黑人| 97视频在线观看播放| 国产亚洲欧美aaaa| 亚洲国产欧美精品| 亚洲色图17p| 欧美性xxxxxxxxx| 久久久久久久久久久人体| 日韩毛片中文字幕| 精品欧美aⅴ在线网站| 少妇av一区二区三区| 国产丝袜一区二区三区| 国产精品视频永久免费播放| 亚洲一二在线观看| 成人中文字幕在线观看| 亚洲国产欧美自拍| 成人97在线观看视频| 亚洲精品久久久久中文字幕欢迎你| 亚洲福利在线播放| 欧美性极品少妇精品网站| 日韩精品免费一线在线观看| 欧美日韩国产综合视频在线观看中文| 国产精品嫩草影院一区二区| 精品国产91久久久久久老师| 亚洲日本中文字幕免费在线不卡| 色噜噜久久综合伊人一本| 日韩精品视频在线播放| 国产视频精品va久久久久久| 成人av色在线观看| 久久免费精品日本久久中文字幕| 国产精品吊钟奶在线| 亚洲美腿欧美激情另类| 亚洲欧美日韩精品久久| 欧美精品在线第一页| 亚洲乱码国产乱码精品精天堂| 国产不卡视频在线| 亚洲欧美在线第一页| 欧美视频专区一二在线观看| 在线看福利67194| 国产日韩在线播放| 久久精品91久久香蕉加勒比| 国产精品a久久久久久| 日韩一级裸体免费视频| 国产精品视频男人的天堂| 91精品国产自产在线观看永久| 91免费视频国产| 日韩在线精品视频| 亚洲一区二区三区乱码aⅴ| 午夜精品久久久久久久久久久久久| 亚洲精品成a人在线观看| 国产高清在线不卡| 成人在线播放av| 亚洲国产高潮在线观看| 一区二区在线免费视频| 欧美孕妇孕交黑巨大网站| 亚洲国产精品女人久久久| 国产精品偷伦免费视频观看的| 97色在线播放视频| 日韩欧美视频一区二区三区| 欧美一区二粉嫩精品国产一线天| 8090成年在线看片午夜| 国产aⅴ夜夜欢一区二区三区| 欧美黄色片免费观看| 91精品久久久久久久久久另类| 欧美三级欧美成人高清www| 国产精品黄页免费高清在线观看| 亚洲精品国产综合区久久久久久久| 国产精品成人av在线| 68精品国产免费久久久久久婷婷|