[LINQ2Dapper]最完整Dapper To Linq框架(八)---导航属性
目录
- [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询
- [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询
- [LINQ2Dapper]最完整Dapper To Linq框架(三)---实体类关系映射
- [LINQ2Dapper]最完整Dapper To Linq框架(四)---Linq和SQL并行使用
- [LINQ2Dapper]最完整Dapper To Linq框架(五)---查看Linq实际执行的SQL
- [LINQ2Dapper]最完整Dapper To Linq框架(六)---多表联合与匿名类型返回
- [LINQ2Dapper]最完整Dapper To Linq框架(七)---仓储模式
- [LINQ2Dapper]最完整Dapper To Linq框架(八)---导航属性
3.1.9.4版本增加新功能导航属性
1.安装
可在Nuget上搜索最新版本(目前是预览版本,只能通过Nuget命令安装)
或者使用Nuget命令
Install-Package Kogel.Dapper.Extension.Mssql 3.1.9.7
(此版本不建议正式项目使用)
2.定义
使用特性ForeignKey定义主外键关系
[Display(Rename = "News")]
public class News:IBaseEntity<News,int>
{
/// <summary>
/// 新闻主键
/// </summary>
[Identity]
public override int Id { get; set; } /// <summary>
/// 内容
/// </summary>
public string Content { get; set; } /// <summary>
/// 评论列表
/// </summary>
[ForeignKey("Id", "ArticleId")]
public List<Comment2> Comments { get; set; }
}
[Display(Rename = "Comment")]
public class Comment : IBaseEntity<Comment,int>
{
[Identity]
public override int Id { get; set; }
/// <summary>
/// 新闻id
/// </summary>
public int ArticleId { get; set; }
/// <summary>
/// 评论内容
/// </summary>
public string Content { get; set; }
}
注意:用到导航属性的实体类需要继承IBaseEntity,最好所有实体类都继承IBaseEntity
(在没有用到导航属性时,导航属性不会起任何作用,查询时也不会返回导航属性数据)
使用导航属性进行条件判断查询
var comment = conn.QuerySet<News1>()
.Where(x => x.Comments.Any(y => y.Id != ))
.ToList();
查询导航属性的数据,并使用Select
var comment11 = conn.QuerySet<News>()
.Where(x => x.Comments.Any(y => y.Id != ))
.Get(x => new NewsDto1
{
Id = x.Id,
Title = x.Content,
CommentDto1 = x.Comments.Select(y => new CommentDto1()
{
Id = y.Id,
Content = y.Content
}).ToList()
});
自定义返回的Dto类需要继承IBaseEntity接口
//需要继承IBaseEntity接口
public class CommentDto1:IBaseEntityDto
{
public int Id { get; set; }
public string Content { get; set; }
}
3. 1对1导航关系
public class Comment : IBaseEntity<Comment,int>
{
[Identity]
public override int Id { get; set; } /// <summary>
/// 内容
/// </summary>
public string Content { get; set; } /// <summary>
/// 新闻id
/// </summary>
public int ArticleId { get; set; } //一条评论对应一条新闻
[ForeignKey("ArticleId","Id")]
public News News { get; set; } }
1对1使用导航属性查询
var comment = conn.QuerySet<Comment>()
.Where(x => x.News.Id == )
.Get();
4.关于导航属性的性能
导航属性的实现是基于1对多或多对多直接关系的连表然后查询出所有主从结果,再利用“回溯二叉树算法”分割数据对应实体之间的关系进行实现
回溯法有通用解法的美称,实际上是一个类似枚举的深度优先收索参试过程,主要是在收索参试过程中寻找问题的解,当发现已不满足求解条件时就回溯返回也就是递归返回,参试别的路径。就是穷举法。
要解决一个回溯问题通常要确定三个元素:
1.选择:对于每一个特定的解,肯定是由一步步构建而来的,而每一步怎么构建,肯定都是有限个选择要怎么选择这个要知道在编程的时候就要定下优先或合法的每一步选择的顺序。
2.条件。对于每一个特定的解的某一步,他必然要符和某个解的特定要求,如果不符合条件,就要回溯。
3.结束。当到达一个特定结束条件的时候,就认为这个一步步构建的解是符合的解了
对于回溯法来说每次递归调用很重要的一点就是把每次递归的不同信息传递给递归调用的函数,最重要的就是把上一步做过的某些事情的这个选择排除避免重复和无限递归。
递归函数参数的选择需要遵循四个原则:
1.必须有一个临时变量因为每一步选择后暂时还没有构成完整的解,这个时候这个选择的不完整的解,也要想办法传递给递归函数,也就是,把每次递归的不同情况传递给递归调用的函数
2.最重要的是在参数设计中可以得到结束条件。
3.要保证递归函数返回时,状态可以恢复到递归前。
框架开源,完整框架源码可以去Github上下载:
https://github.com/a935368322/Kogel.Dapper.Extension
如有问题也可以加QQ群讨论:
技术群 710217654
[LINQ2Dapper]最完整Dapper To Linq框架(八)---导航属性的更多相关文章
- [LINQ2Dapper]最完整Dapper To Linq框架(七)---仓储模式
目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...
- [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询
此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper 支持.net framework4.5.1 ...
- [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询
目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...
- [LINQ2Dapper]最完整Dapper To Linq框架(三)---实体类关系映射
此特性需要安装Kogel.Dapper.Mssql或者Oracle 3.06及以上版本,实体类层需要安装Kogel.Dapper.Extension 3.06及以上版本 目录 [LINQ2Dapper ...
- [LINQ2Dapper]最完整Dapper To Linq框架(四)---Linq和SQL并行使用
目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...
- [LINQ2Dapper]最完整Dapper To Linq框架(五)---查看Linq实际执行的SQL
此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper支持.net framework4.6.1及 ...
- [LINQ2Dapper]最完整Dapper To Linq框架(六)---多表联合与匿名类型返回
目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...
- EntityFramework、Dapper vs 草根框架性能
EntityFramework.Dapper vs 草根框架性能 扯淡 当前市面上 ORM 很多,有跑车型的,如 Dapper,有中规中矩型的,如 Mybatis.Net,也有重量型的,如 Entit ...
- .NET深入解析LINQ框架2
1].开篇介绍 在开始看本篇文章之前先允许我打断一下各位的兴致.其实这篇文章本来是没有打算加“开篇介绍”这一小节的,后来想想还是有必要反馈一下读者的意见.经过前三篇文章的详细讲解,我们基本上对LINQ ...
随机推荐
- 2018-8-10-Roslyn-节点的-Span-和--FullSpan-有什么区别
title author date CreateTime categories Roslyn 节点的 Span 和 FullSpan 有什么区别 lindexi 2018-08-10 19:16:52 ...
- shell不排序去重
一条命令搞定: awk '!a[$0]++' file 如果是第一次出现a[$0]++的值为0(假),而!a[$0]++的值就为1(真),之后就执行print $0 第二次或者两次以上的出现a[$ ...
- 【[Offer收割]编程练习赛9 B】水陆距离
[题目链接]:http://hihocoder.com/problemset/problem/1478 [题意] [题解] 一开始把所有的水域的位置都加入到队列中去; 然后跑一个bfs. 第一次到达的 ...
- CF986F Oppa Funcan Style Remastered
CF986F Oppa Funcan Style Remastered 不错的图论转化题! 题目首先转化成:能否用若干个k的非1因数的和=n 其次,因数太多,由于只是可行性,不妨直接都用质因子来填充! ...
- poj 1092 Farmland (Geometry)
1092 -- Farmland 怎么最近做几何题都这么蛋疼,提交C++过不了交G++就过了.据我估计,原因是用了atan2这个函数,或者是其他一些函数造成了精度的影响.不管怎样,这题最后还是过了~ ...
- Mybatis/Ibatis,数据库操作的返回值
该问题,我百度了下,根本没发现什么有价值的文章:还是看源代码(详见最后附录)中的注释,最有效了!insert,返回值是:新插入行的主键(primary key):需要包含<selectKey&g ...
- jQuery对html元素的取值与赋值实例详解
jQuery对html元素的取值与赋值实例详解 转载 2015-12-18 作者:欢欢 我要评论 这篇文章主要介绍了jQuery对html元素的取值与赋值,较为详细的分析了jQuery针对常 ...
- 2019-8-31-PowerShell-通过-WMI-获取系统信息
title author date CreateTime categories PowerShell 通过 WMI 获取系统信息 lindexi 2019-08-31 16:55:58 +0800 2 ...
- 第三期 第三期 搜索——1.运动规划(motion_planing)
运动规划的根本问题在于机器人可能存在于一个这样的世界中, 它可能想找到一条到达这个目标的路径,那么就需要指定一个到达那里的计划, 自动驾驶汽车也会遇到这个问题.他可能处于高速公路的附近的街道网络中,他 ...
- 小程序加载大图片 使用widthFix时,图片先拉伸然后才显示完全
<image src="http://www.ll.com/sss.jpg" mode="widthFix" style="width:180r ...