校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > ASP.NET Mvc開發之查詢數據

ASP.NET Mvc開發之查詢數據

熱門標簽:濮陽外呼電銷系統怎么樣 塔城代理外呼系統 地圖標注專業團隊 地圖定位圖標標注 天心智能電銷機器人 地圖標注的公司有哪些 代理接電話機器人如何取消 400電話辦理哪家性價比高 遂寧市地圖標注app

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

edmx文件的代碼樹如下:

①怎么會是XML文件?

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

 ②.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 DbSetBlogArticle> BlogArticles { get; set; }
    public DbSetBlogArticleCate> BlogArticleCates { get; set; }
    public DbSetBlogUser> BlogUsers { get; set; }
    public DbSetEnumeration> Enumerations { get; set; }
  }

  實體類。

  而另一個.tt文件生成的類是做什么用呢?我們打開一個看代碼:

 //EF按照實體模型生成的實體類
  public partial class BlogArticleCate
  {
    public BlogArticleCate()
    {
      this.BlogArticles = new HashSetBlogArticle>();
    }
  
    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 ICollectionBlogArticle> 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表達式來獲取數據
      //返回一個ListT>的對象來存儲文章列表
      List  Models.BlogArticle > list= db.BlogArticles.Where(p => p.AIsDel == false).ToList();
      
      
      //也可以使用Linq來獲取數據 
      ListModels.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 ListBlogArticle>)
      {
        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>

運行的結果如下:

三、總結

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

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

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

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

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

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

您可能感興趣的文章:
  • asp.net mvc 從數據庫中讀取圖片的實現代碼
  • asp.net mvc4 mysql制作簡單分頁組件(部分視圖)
  • 利用ASP.NET MVC+EasyUI+SqlServer搭建企業開發框架
  • 使用jQuery向asp.net Mvc傳遞復雜json數據-ModelBinder篇
  • ASP.NET MVC DropDownList數據綁定及使用詳解
  • ASP.NET中MVC從后臺控制器傳遞數據到前臺視圖的方式
  • Asp.net mvc 數據調用示例代碼
  • ASP.NET MVC 數據驗證及相關內容
  • ASP.NET Mvc開發之刪除修改數據
  • ASP.NET中MVC傳遞數據的幾種形式總結
  • JQuery對ASP.NET MVC數據進行更新刪除
  • asp.net實現的MVC跨數據庫多表聯合動態條件查詢功能示例
  • ASP.NET MVC使用EPPlus,導出數據到Excel中

標簽:重慶 汕頭 河南 本溪 宜春 婁底 吉林 麗江

巨人網絡通訊聲明:本文標題《ASP.NET Mvc開發之查詢數據》,本文關鍵詞  ASP.NET,Mvc,開,發之,查詢,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ASP.NET Mvc開發之查詢數據》相關的同類信息!
  • 本頁收集關于ASP.NET Mvc開發之查詢數據的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    青青草国产精品亚洲专区无| 国产精品不卡视频| 99久久99久久精品免费看蜜桃| 一本色道亚洲精品aⅴ| av亚洲精华国产精华精华| 国产亚洲精品免费| 久久不见久久见免费视频1| 亚洲成人一区在线| 精品美女一区二区| 成人18视频日本| 国产精品一区一区| 免费在线欧美视频| 欧美日韩美女一区二区| 色先锋aa成人| 一本久久a久久精品亚洲| 99国产欧美另类久久久精品| 欧美激情综合五月色丁香小说| 91精品国产91久久久久久一区二区| 精品系列免费在线观看| 91视频在线观看免费| 久久人人爽爽爽人久久久| 日韩一级黄色大片| 色婷婷国产精品| 中文字幕欧美国产| 欧美videofree性高清杂交| 成人va在线观看| 精品国产乱码久久久久久蜜臀| 北条麻妃一区二区三区| 99热这里都是精品| 一区二区三区视频在线看| 欧美丝袜丝交足nylons| 欧美三级电影一区| 91国偷自产一区二区使用方法| 免费人成精品欧美精品| 亚洲尤物在线视频观看| 亚洲黄色片在线观看| 51精品秘密在线观看| 日韩电影一区二区三区| 捆绑调教美女网站视频一区| 国产剧情一区二区| 蜜臀久久久99精品久久久久久| 日韩精品一区二区在线观看| 欧美国产一区二区在线观看| 欧美日韩精品免费| av亚洲精华国产精华精华 | 精品国产乱码久久| 欧美一级免费观看| 日韩丝袜美女视频| 欧美一区二区三区公司| 日韩高清国产一区在线| 精品日韩一区二区三区免费视频| 国产亲近乱来精品视频 | 国产很黄免费观看久久| 国产成人在线色| 高清不卡在线观看| 欧美性xxxxxxxx| 久久精品二区亚洲w码| 大胆亚洲人体视频| 国产精品91xxx| 亚洲国产毛片aaaaa无费看| 欧美一区二区三区影视| 一区二区三区在线视频观看58| 热久久免费视频| 国产精品一线二线三线精华| 狠狠狠色丁香婷婷综合激情| 欧美国产精品中文字幕| 亚洲欧美aⅴ...| 奇米影视7777精品一区二区| 国产一区福利在线| 国产精品理论在线观看| 久久精品国产久精国产爱| 久久66热偷产精品| 九一九一国产精品| 久久 天天综合| 色综合久久久久综合体桃花网| 国产福利一区二区| 国产一区二区在线视频| 麻豆91在线播放| 成人激情小说网站| 在线观看日韩毛片| 欧美一卡二卡三卡| 色拍拍在线精品视频8848| 日韩欧美一区二区在线视频| 亚洲愉拍自拍另类高清精品| 免费视频最近日韩| 视频一区免费在线观看| 国产一级精品在线| 欧美成人激情免费网| 久久久久久免费网| 天天爽夜夜爽夜夜爽精品视频 | 国产999精品久久| 国产精华液一区二区三区| 免费欧美在线视频| av爱爱亚洲一区| 日本一区二区视频在线观看| 精品国产免费久久| 99re热视频这里只精品| 精品1区2区3区| 欧美高清视频不卡网| 国产精品久久久久久户外露出| 97久久精品人人做人人爽| 欧美在线观看视频在线| 久久久99久久| 99久久国产免费看| 2021国产精品久久精品| 美美哒免费高清在线观看视频一区二区 | 精品国产露脸精彩对白| 一区二区三区四区亚洲| 精品日本一线二线三线不卡 | 久久精品免费在线观看| 久久亚洲精品国产精品紫薇| 精品处破学生在线二十三| 亚洲乱码国产乱码精品精98午夜 | 国产偷国产偷亚洲高清人白洁| 中文字幕免费不卡| 五月天婷婷综合| 黄网站免费久久| 91美女在线看| 亚洲一区二区三区爽爽爽爽爽| 日韩二区三区在线观看| 亚洲色图制服诱惑| 成人免费视频一区二区| 91精品国产综合久久久久久漫画 | 国产精品久久久久一区| 中文字幕欧美国产| 北条麻妃国产九九精品视频| 亚洲欧美国产三级| 久久精品噜噜噜成人88aⅴ| 日韩一二在线观看| 国产精品天干天干在观线| www.欧美色图| 亚洲人一二三区| 99riav一区二区三区| 欧美日韩在线播放| 午夜伊人狠狠久久| 欧美一区二区三区播放老司机| 欧美aaaaa成人免费观看视频| 91高清在线观看| 亚洲国产精品成人综合色在线婷婷 | 成人黄色片在线观看| 91精品国产综合久久久久久| 蜜臂av日日欢夜夜爽一区| 色综合久久中文综合久久牛| 亚洲国产精品一区二区www在线| 日本韩国视频一区二区| 亚洲精品在线免费观看视频| 国产经典欧美精品| 欧美日韩你懂得| 久久9热精品视频| 99精品国产热久久91蜜凸| 欧美老肥妇做.爰bbww视频| 国产盗摄女厕一区二区三区| 久久亚洲影视婷婷| 国产91丝袜在线播放0| 一区二区在线观看免费| 99麻豆久久久国产精品免费 | 蜜臀久久99精品久久久久久9 | 亚洲丰满少妇videoshd| 国产日韩欧美电影| 欧美日韩高清影院| 亚洲欧美日韩国产手机在线 | 国产精品成人免费在线| 欧美视频一区二| 国产日韩欧美精品电影三级在线| 成人永久免费视频| 亚洲影院在线观看| 日韩精品中文字幕在线一区| 色婷婷综合久久久久中文一区二区| 国产精品网站在线观看| 久久丁香综合五月国产三级网站| 欧美大度的电影原声| 成人天堂资源www在线| 久久男人中文字幕资源站| www.久久精品| 亚洲欧洲性图库| 久久日一线二线三线suv| 久久99精品久久久久婷婷| 久久先锋影音av鲁色资源网| 亚洲风情在线资源站| 日韩欧美国产一区二区在线播放 | 久久99精品久久久久| 欧美一区二区三区在线观看 | 在线综合视频播放| 国产又黄又大久久| 亚洲国产欧美在线人成| 精品一区二区三区蜜桃| 99国产精品视频免费观看| 蜜桃av噜噜一区二区三区小说| 亚洲美女屁股眼交| 色老综合老女人久久久| 国产精品三级电影| 黑人精品欧美一区二区蜜桃| 国产精品久久久久久久第一福利 | 欧美三级韩国三级日本一级| 日本亚洲视频在线| 亚洲综合自拍偷拍| 久久青草欧美一区二区三区| 亚洲人成网站影音先锋播放| www.一区二区| 亚洲自拍偷拍av|