.net core EF Core 视图的应用

由之前的一篇文章《.net core Entity Framework 与 EF Core》我们都已经知道 EF Core 增加了许多特性,并且性能上也有了很大的提升。

但是EF Core是不支持存储过程及视图的映射的,那么直接通过 DbContext 是没有办法直接调用(就是不能直接 "点" 出来)到存储过程与视图的。

上一篇《.net core EF Core 调用存储过程》中已经讲到了存储过程的调用了,这篇就只讲视图了。

对视图来讲,在数据库中 EF Core 根本不知道分不清数据表跟视图的区别,这也导致了无法直接通过 DbContext 直接进行调用视图。

我们来用最简单的 一个.net core 提供的映射的方法 -- DbQuery(还是用之前的测试数据库),直接用 mssql 管理工具创建视图:

创建好视图后,我们同样可以在数据库中看到这个视图:

视图就准备好了,那么,我们接口手动创建一个,用于映射的实体,里面的字段与视图返回的结果一致,名称就无所谓了,因为可以直接映射到对应的视图:

    public class View_BookDetails
    {
        public int Id { get; set; }
        public int Cateid { get; set; }
        public string Name { get; set; }
        public string Author { get; set; }
        public DateTime Createtime { get; set; }
        public bool Isdel { get; set; }
        public string CateName { get; set; }
    }

接下来就是使用 DbQuery 进行映射了

    public partial class LibraryContext : DbContext
    {
        public LibraryContext()
        {
        }

        public LibraryContext(DbContextOptions<LibraryContext> options)
            : base(options)
        {
        }

        public DbQuery<View_BookDetails> View_BookDetails { get; set; }

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            modelBuilder.HasAnnotation("ProductVersion", "2.2.3-servicing-35854");

            modelBuilder.Query<View_BookDetails>().ToView("View_BookTable");

        }
    }

重点就两句:

我们调用试试看,通过映射后,我们可以直接 "点" 出来了:

   //调用视图
   var books = _context.View_BookDetails.ToList();

结果:

用这个简单的方式,就可以调用到映射好的视图了。当然,我们还可以换一种方法去查,直接去掉  这句,这句只是在 DbContext 上下文中进行了预定义而已。Dbset 是允许这样的,同样 DbContext 实例的 Set 方法也可以。然后用下面的这句,查出来的结果是一样的:

   var results = _context.Query<View_BookDetails>().ToList();

同样的,我们也可以用 Linq 去进行条件查询,比如:

   //调用视图
   var books = _context.View_BookDetails.Where(x=>x.Name.Contains("C#高级")).ToList();

挺有意思的吧,当然,不在 DbContext 上下文中进行了预定义的方式也是一样一样的,可以举一反三地去玩一下。

最后来点有意思的,modelBuilder 那里还有另外一种玩法(这玩法不新鲜,不常用),我另外定义一个实体,主要是用来统计的:

(1)定义统计的实体类 CateStatsView:

    /// <summary>
    /// 分类中书的数量及作者清单:统计书的数量和作者的数量
    /// </summary>
    public class CateStatsView
    {
        public CateStatsView(string name, int bookCount, int authorCount)
        {
            Name = name;
            BookCount = bookCount;
            AuthorCount = authorCount;
        }

        public string Name { get;  set; }
        public int BookCount { get;  set; }
        public int AuthorCount { get;  set; }
    }

(2)在 OnModelCreating 中定义查询的实体,并在进行统计:

     modelBuilder.Query<CateStatsView>().ToQuery(
         () => Categories.Select(m => new CateStatsView(
             m.Name,
             m.Books.Count,
             m.Books.Select(a => a.Author).Distinct().Count()
             )
         )
     );

(3)调用并返回结果:

    var results = _context.Query<CateStatsView>().ToList();

结果:

最后:视图的作用的话,本来就是可以理解成表,本质上来讲,生成的也就是 SQL 语句进行查询。这次讲的都是很简单的 .net core 中视图的应用。实现的方式都是多种多样的,就像条条大路通罗马。了解多点不是坏事。

原文地址:https://www.cnblogs.com/Vam8023/p/10789131.html

时间: 2024-07-31 09:33:26

.net core EF Core 视图的应用的相关文章

asp.net core+ef core

asp.net core+ef core 官方的文档https://docs.asp.net/en/latest/tutorials/first-mvc-app/start-mvc.html 先来看一下实现的效果 开始之前,确定本机已经有.NET Core环境.https://www.microsoft.com/net/core#windows 1.创建解决方案的文件结构如下图(模糊处理的过文件是自己后面加的和ef生成的). 2.要使用ef core,先引用ef core相关的程序包.https

在vs2015上使用asp.net core+ef core

官方的文档https://docs.asp.net/en/latest/tutorials/first-mvc-app/start-mvc.html 先来看一下实现的效果 开始之前,确定本机已经有.NET Core环境.https://www.microsoft.com/net/core#windows 1.创建解决方案的文件结构如下图(模糊处理的过文件是自己后面加的和ef生成的). 2.要使用ef core,先引用ef core相关的程序包.https://docs.efproject.net

[.Net Core] EF Core实践(DB First)

一.开发环境: VS2015, .Net Core 1.0.0-preview2-003156 二.准备数据: CREATE DATABASE [Blogging]; GO USE [Blogging]; GO CREATE TABLE [Blog] ( [BlogId] int NOT NULL IDENTITY, [Url] nvarchar(max) NOT NULL, CONSTRAINT [PK_Blog] PRIMARY KEY ([BlogId]) ); GO CREATE TAB

asp.net core ef core mysql 新增数据并发异常处理

net core 2.0发布后,一直想体验下,因种种原因,一直在拖着没进行. 前阵子公司要加个新的内部管理后台,正好可以用asp.net core来做下,体验下net core的魅力. 啃过文档后就上手了,一切很顺利. 直到周五,出现了一个并发异常的问题,本以为可以很快处理掉的,但没想到一直花费了很长时间才解决掉,现在记录下情况,有相同经历的伙伴以后可以参考. 先上异常截图. 异常提示: Microsoft.EntityFrameworkCore.DbUpdateConcurrencyExcep

asp.net Core EF core ( Entity Framework 7 ) 数据库更新维护

CreateData-baseIfNotExists等之前的API已经废弃,现在采用的是微软封装好,简化.高效的API,migrations 因为,旧API,要付出高昂的代价,以及局限性 打开VS2017,选择工具->NutGet包管理器->程序包管理器控制台 1.输入Add-Migration MyFirstMigration 指令 就会根据当前的dbcontext自动生成Migrations文件夹及文件,这些文件用于新建.或者扩展专属于Migrations 这个API的扩展的数据库 然后在

EntityFramework Core技术线路(EF7已经更名为EF Core,并于2016年6月底发布)

官方文档英文地址:https://github.com/aspnet/EntityFramework/wiki/Roadmap 历经延期和更名,新版本的实体框架终于要和大家见面了,虽然还有点害羞.请大家多体谅! 下面正式进入主题: Entity Framework Core (EF Core) 下面是EF Core 的计划和技术线路,注意,这些计划是可能发现变化的,因为很多事是很难预测的.即便如此,我们还是尽可能保持计划的公开和透明,以解大家对EF Core期望,以及做出相应的安排. Sched

[转]EntityFramework Core技术线路(EF7已经更名为EF Core,并于2016年6月底发布)

本文转自:http://www.cnblogs.com/VolcanoCloud/p/5572408.html 官方文档英文地址:https://github.com/aspnet/EntityFramework/wiki/Roadmap 历经延期和更名,新版本的实体框架终于要和大家见面了,虽然还有点害羞.请大家多体谅! 下面正式进入主题: Entity Framework Core (EF Core) 下面是EF Core 的计划和技术线路,注意,这些计划是可能发现变化的,因为很多事是很难预测

SQLite EF Core Database Provider

原文链接 This database provider allows Entity Framework Core to be used with SQLite. The provider is maintained as part of the Entity Framework Core project. Supported Database Engines SQLite (3.7 onwards) Supported Platforms .NET Framework (4.5.1 onward

EF Core 快速上手——EF Core 入门

EF Core 快速上手--EF Core 介绍 本章导航 从本书你能学到什么 对EF6.x 程序员的一些话 EF Core 概述 1.3.1 ORM框架的缺点 第一个EF Core应用 ??本文是对<Entity framework in action>部分章节的翻译,某些场景也会附上笔者实践的Demo.尽管很认真的斟酌,但是水平有限,还请各位批评和斧正. ??Entity Framework Core, 或者 EF Core,是一个方便软件工程师访问数据库的库.有很多方法来构建这样的一个库