婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > ASP.NET Mvc開發(fā)之查詢數(shù)據(jù)

ASP.NET Mvc開發(fā)之查詢數(shù)據(jù)

熱門標(biāo)簽:濮陽外呼電銷系統(tǒng)怎么樣 塔城代理外呼系統(tǒng) 地圖標(biāo)注專業(yè)團(tuán)隊(duì) 地圖定位圖標(biāo)標(biāo)注 天心智能電銷機(jī)器人 地圖標(biāo)注的公司有哪些 代理接電話機(jī)器人如何取消 400電話辦理哪家性價(jià)比高 遂寧市地圖標(biāo)注app

對于.NET平臺(tái)上開發(fā)WebForm項(xiàng)目,程序員操作數(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í)體對象操作數(shù)據(jù)表中數(shù)據(jù)的一種面向?qū)ο蟮牟僮骺蚣埽唧w的底層也是調(diào)用ADO.NET。

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

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

1)怎么創(chuàng)建實(shí)體對象模型文件

①創(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ù)庫對象,選擇”確定所生成對象的單復(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è)表跟我們在數(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í)體對象和數(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í)體對象包裝類的狀態(tài)屬性,生成不同的SQL語句執(zhí)行
  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; }
  }

  實(shí)體類。

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

 //EF按照實(shí)體模型生成的實(shí)體類
  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; }
  }

很容易的發(fā)現(xiàn)這些字段和我們數(shù)據(jù)庫中的字段是對應(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)建該類的對象,并且操作數(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表達(dá)式來獲取為被刪除的文章
      
      //使用Lamabda表達(dá)式來獲取數(shù)據(jù)
      //返回一個(gè)ListT>的對象來存儲(chǔ)文章列表
      List  Models.BlogArticle > list= db.BlogArticles.Where(p => p.AIsDel == false).ToList();
      
      
      //也可以使用Linq來獲取數(shù)據(jù) 
      ListModels.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ù),
因?yàn)槲覀冃枰褂肂logArticle對象來顯示數(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 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>

運(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í)體對象和數(shù)據(jù)庫映射關(guān)系;

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

4)實(shí)體對象可以使用Lamabda表達(dá)式或者Linq來查詢需要的數(shù)據(jù),并且使用一個(gè)List對象來存儲(chǔ)數(shù)據(jù);

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

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。

您可能感興趣的文章:
  • asp.net mvc 從數(shù)據(jù)庫中讀取圖片的實(shí)現(xiàn)代碼
  • asp.net mvc4 mysql制作簡單分頁組件(部分視圖)
  • 利用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對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中

標(biāo)簽:重慶 汕頭 河南 本溪 宜春 婁底 吉林 麗江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ASP.NET Mvc開發(fā)之查詢數(shù)據(jù)》,本文關(guān)鍵詞  ASP.NET,Mvc,開,發(fā)之,查詢,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ASP.NET Mvc開發(fā)之查詢數(shù)據(jù)》相關(guān)的同類信息!
  • 本頁收集關(guān)于ASP.NET Mvc開發(fā)之查詢數(shù)據(jù)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    欧美一区二区三区啪啪| 国产黄色精品视频| 免费高清在线一区| 天天综合天天综合色| 麻豆91精品视频| 国产成人免费在线观看不卡| 一本在线高清不卡dvd| 欧美videofree性高清杂交| 亚洲在线视频网站| 国产精品国产a级| 亚洲一区二区三区四区在线| 久久九九99视频| 99免费精品在线观看| 欧美网站一区二区| 日本视频免费一区| 日韩毛片精品高清免费| 亚洲视频一区二区在线观看| 国产精品国产三级国产aⅴ原创| 日韩欧美中文字幕一区| 一区二区三区电影在线播| 一区二区三区产品免费精品久久75| 日韩欧美国产三级| 欧美午夜理伦三级在线观看| 中文字幕亚洲区| 午夜精品久久久久久久99水蜜桃| 色婷婷综合久久久中文字幕| 欧美精选一区二区| 蜜臀av一区二区在线观看| 日韩成人免费电影| 日韩小视频在线观看专区| 精品国产乱码久久久久久久久| 美女看a上一区| 麻豆91在线观看| 久久嫩草精品久久久精品一| 欧美激情一区三区| 国产99久久久精品| 亚洲精品伦理在线| 国产ts人妖一区二区| 最新欧美精品一区二区三区| 国产日韩精品一区二区浪潮av| 亚洲国产乱码最新视频| 欧美一级爆毛片| 欧美偷拍一区二区| 亚洲色图欧美偷拍| 成人午夜激情在线| 国产精品亚洲综合一区在线观看| 欧美猛男男办公室激情| 一区二区三区精品在线观看| 中文字幕成人在线观看| 一区二区三区四区蜜桃| 国产一区欧美一区| 亚洲精品视频在线观看免费| 欧美日韩国产区一| 亚洲一区二区不卡免费| 国产成人精品亚洲日本在线桃色| 看国产成人h片视频| 一区二区三区免费看视频| 国产精品视频麻豆| 在线观看欧美黄色| 久久精品一区蜜桃臀影院| 91一区一区三区| 欧美日本免费一区二区三区| 日本系列欧美系列| 久久精品国产澳门| 亚洲欧美日韩一区二区 | 欧美日韩综合在线| 欧美一区二区在线看| 国产91丝袜在线播放九色| 一区二区三区欧美久久| 国产精品久久久久久亚洲伦| 精品视频一区二区不卡| 国产精品国产三级国产aⅴ原创| 中文字幕亚洲不卡| 色诱视频网站一区| 欧美精品在线观看播放| 国产成人亚洲综合色影视| 欧美在线综合视频| 成人网在线免费视频| 精品国产伦一区二区三区观看体验| 在线免费观看日本欧美| 中文字幕一区二区三区av| 日韩精品一区在线观看| 日韩av电影天堂| 亚洲一区二区三区在线播放| 成人激情开心网| 国产福利精品一区二区| 久久综合色一综合色88| 一区二区三区在线影院| 婷婷开心激情综合| 国产精品视频九色porn| 亚洲h精品动漫在线观看| 久久97超碰色| 亚洲精品综合在线| 欧美少妇一区二区| 国产精品一二三四五| 欧美xxxx老人做受| 99久久婷婷国产综合精品电影| 综合久久久久久久| 亚洲一区免费观看| 国产一区亚洲一区| 欧美日韩一本到| 国产亚洲美州欧州综合国| 欧美色精品天天在线观看视频| 国产激情视频一区二区在线观看| 国产91高潮流白浆在线麻豆| 国产日韩亚洲欧美综合| 亚洲欧美一区二区三区孕妇| 久久成人免费日本黄色| 亚洲精选免费视频| 国产九色精品成人porny | 国产成人自拍高清视频在线免费播放| 日韩一区欧美二区| 国产免费观看久久| 中文字幕精品一区二区三区精品| 色狠狠综合天天综合综合| 蜜臀av亚洲一区中文字幕| 国产精品久久久久久久久果冻传媒| 亚洲国产精品视频| 亚洲图片欧美视频| 91在线观看高清| 日本韩国欧美一区二区三区| 91亚洲精品乱码久久久久久蜜桃| 日韩精品一区二区三区中文精品| 一区二区成人在线视频 | 日本一区二区动态图| 亚洲欧洲日韩综合一区二区| 国产激情一区二区三区| 亚洲国产精品高清| 性久久久久久久| 国内外精品视频| 日韩欧美不卡一区| 成人精品在线视频观看| 91在线视频免费观看| 精彩视频一区二区| 成人91在线观看| 蜜臀久久99精品久久久久久9| 国产一区二区不卡老阿姨| 国产精品的网站| 天天做天天摸天天爽国产一区| 中文乱码免费一区二区| 日本美女一区二区三区| 欧美一区二区三区小说| 欧美日韩一区二区不卡| 一区二区三区在线视频免费观看| 日韩综合小视频| 久久综合色综合88| 色婷婷av一区二区三区软件| 不卡的av网站| 欧美午夜电影一区| 成人国产视频在线观看| 欧美欧美欧美欧美| 午夜精品一区在线观看| 国产精品资源在线| 色综合婷婷久久| 99天天综合性| 欧美成人aa大片| 91精品国产综合久久蜜臀 | 精品日韩在线观看| 欧美另类久久久品| 国产精品久久久久久久久动漫| 久久久久九九视频| 亚洲影院久久精品| 一区二区三国产精华液| 亚洲精品高清在线观看| 亚洲欧美日韩在线| 亚洲精品成人在线| 91精品欧美一区二区三区综合在| 亚洲手机成人高清视频| 国产精品2024| 99热精品一区二区| 久久久一区二区| 国产色产综合产在线视频| 美女精品一区二区| 九色综合国产一区二区三区| 欧美日韩国产免费一区二区| 国产在线国偷精品免费看| 91精品国产综合久久香蕉麻豆| 亚洲精品视频在线观看免费| 亚洲主播在线观看| 免费看日韩精品| 亚洲丝袜自拍清纯另类| 成人免费看黄yyy456| 不卡大黄网站免费看| 久久新电视剧免费观看| 久久久国产一区二区三区四区小说| 午夜精品久久久久久不卡8050| 亚洲国产综合人成综合网站| 亚洲精品日日夜夜| 成人高清在线视频| 制服丝袜亚洲播放| 欧美写真视频网站| 日韩免费在线观看| 欧美成人激情免费网| 国产亲近乱来精品视频| 国产精品第一页第二页第三页| 亚洲免费av高清| 开心九九激情九九欧美日韩精美视频电影 | 亚洲国产高清在线| 亚洲小少妇裸体bbw| 国产河南妇女毛片精品久久久|