• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >ASP.NET > ASP.NET Mvc开发之查询数据

ASP.NET Mvc开发之查询数据

作者:强_子 字体:[增加 减小] 来源:互联网 时间:2017-05-11

强_子通过本文主要向大家介绍了asp net mvc,asp net mvc 4,asp net mvc 5,精通asp.net mvc 5,精通asp.net mvc 4等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

对于.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 DbSet<BlogArticle> BlogArticles { get; set; }
    public DbSet<BlogArticleCate> BlogArticleCates { get; set; }
    public DbSet<BlogUser> BlogUsers { get; set; }
    public DbSet<Enumeration> Enumerations { get; set; }
  }
</div>

  实体类。

  而另一个.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; }
  }
</div>

很容易的发现这些字段和我们数据库中的字段是对应的,这就是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

</div>

接着我们为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>

</div>

运行的结果如下:

三、总结

1)EF框架根据我们的数据库中数据模型生成实体数据模型;

2)实体数据模型为一个edmx文件,且该文件为一个标准的XML文件,主要描述实体对象和数据库映射关系;

3).tt文件为我们生成了数据库上下文类(用于操作数据库)和实体类(表示实体对象和外键属性关系);

4)实体对象可以使用Lamabda表达式或者L

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 详解ASP.NET MVC 常用扩展点:过滤器、模型绑定
  • ASP.NET MVC从视图传参到控制器的几种形式
  • ASP.NET MVC 4 中的JSON数据交互的方法
  • ASP.NET MVC制作404跳转实例(非302和200)
  • 详解ASP.NET MVC 利用Razor引擎生成静态页
  • 详解ASP.NET MVC 解析模板生成静态页(RazorEngine)
  • ASP.NET MVC4 利用uploadify.js多文件上传
  • ASP.NET mvc4中的过滤器的使用
  • Asp.net MVC下使用Bundle合并、压缩js与css文件详解
  • 详解Asp.Net MVC——控制器与动作(Controller And Action)

相关文章

  • 2017-05-11ASP.NET用户控件如何使用
  • 2017-05-11ASP.Net PlaceHolder、Panel等控件未实现INamingContainer,导致FindControl无效
  • 2017-05-11asp.net文件上传带进度条实现案例(多种风格)
  • 2017-05-11ASP.NET 提高首页性能的十大做法
  • 2017-05-11Repeater控件实现编辑、更新、删除等操作示例代码
  • 2018-08-20浅谈Asp.net Mvc之Action如何传多个参数的方法
  • 2017-05-11ASP.NET控件10个最有用的属性详解
  • 2017-05-11ASP.NET 运行时错误: 没有为扩展名“.asax”注册的生成提供程序修正版
  • 2018-08-20ASP.NET Core中实现用户登录验证的最低配置示例代码
  • 2017-05-11jQuery AJax调用asp.net webservers的实现代码

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • ASP.NET常用函数(推荐)
    • .net搜索查询并实现分页实例
    • asp.net(C#)中上传大文件的几中常见应用方法
    • asp.net 更改gridview pageSize的方法
    • ASP.NET检测到不安全 Request.Form 值解决方案汇总
    • asp.net 独立Discuz头像编辑模块分离打包
    • ASP.NET中ServerPush用法实例分析
    • ASP.NET实现上传图片并生成缩略图的方法
    • 支持Ajax跨域访问ASP.NET Web Api 2(Cors)的示例教程
    • Asp.net XML文档进行添加删改操作的实例代码

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有