目录

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框架(八)---导航属性的更多相关文章

  1. [LINQ2Dapper]最完整Dapper To Linq框架(七)---仓储模式

    目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...

  2. [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询

    此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper 支持.net framework4.5.1 ...

  3. [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询

    目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...

  4. [LINQ2Dapper]最完整Dapper To Linq框架(三)---实体类关系映射

    此特性需要安装Kogel.Dapper.Mssql或者Oracle 3.06及以上版本,实体类层需要安装Kogel.Dapper.Extension 3.06及以上版本 目录 [LINQ2Dapper ...

  5. [LINQ2Dapper]最完整Dapper To Linq框架(四)---Linq和SQL并行使用

    目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...

  6. [LINQ2Dapper]最完整Dapper To Linq框架(五)---查看Linq实际执行的SQL

    此例子是使用LINQ2Dapper封装,效率优于EntityFramwork,并且支持.NetFramework和.NetCore框架,只依赖于Dapper支持.net framework4.6.1及 ...

  7. [LINQ2Dapper]最完整Dapper To Linq框架(六)---多表联合与匿名类型返回

    目录 [LINQ2Dapper]最完整Dapper To Linq框架(一)---基础查询 [LINQ2Dapper]最完整Dapper To Linq框架(二)---动态化查询 [LINQ2Dapp ...

  8. EntityFramework、Dapper vs 草根框架性能

    EntityFramework.Dapper vs 草根框架性能 扯淡 当前市面上 ORM 很多,有跑车型的,如 Dapper,有中规中矩型的,如 Mybatis.Net,也有重量型的,如 Entit ...

  9. .NET深入解析LINQ框架2

    1].开篇介绍 在开始看本篇文章之前先允许我打断一下各位的兴致.其实这篇文章本来是没有打算加“开篇介绍”这一小节的,后来想想还是有必要反馈一下读者的意见.经过前三篇文章的详细讲解,我们基本上对LINQ ...

随机推荐

  1. SDUT-2772_数据结构实验之串一:KMP简单应用

    数据结构实验之串一:KMP简单应用 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 给定两个字符串string1和str ...

  2. python 自动识别黄图

    from watchdog.observers import Observerfrom watchdog.events import *import timeimport sysimport osim ...

  3. Java中的Runnable、Callable、Future、FutureTask的区别与示例

    Java中存在Runnable.Callable.Future.FutureTask这几个与线程相关的类或者接口,在Java中也是比较重要的几个概念,我们通过下面的简单示例来了解一下它们的作用于区别. ...

  4. shell 并发执行任务

    #!/bin/bash # ref: https://blog.csdn.net/spch2008/article/details/51433353 token(){ pid=$ # 判断是否有传入p ...

  5. 唯一索引与非唯一索引区别(UNIQUE INDEX, NON-UNIQUE INDEX)

    索引是我们经常使用的一种数据库搜索优化手段.适当的业务操作场景使用适当的索引方案可以显著的提升系统整体性能和用户体验.在Oracle中,索引有包括很多类型.不同类型的索引适应不同的系统环境和访问场景. ...

  6. oracle函数 ln(y)

    [功能]返回以e为底的y的对数(e为数学常量) [参数]y,数字型表达式 (条件y>0) [返回]数字 [示例] select exp(3),exp(-3),ln(20.0855369),ln( ...

  7. PHP会话技术

    由于HTTP协议是无连接.无状态的,所以HTTP协议无法记住客户端的信息.为了弥补HTTP协议的这两种不足,所以出现了会话技术. 1 Cookie技术 1.1 什么是Cookie 服务器端,将能够唯一 ...

  8. AtCoder Beginner Contest 077 C Snuke Festival(二分)

    二分水题,A,B,C三个数组排序,对于每个B[i],二分算出来有多少A比他小,多少C比他大,然后扫一遍出结果.O(nlog(n))水过. #include <bits/stdc++.h> ...

  9. Python--day41--threading中的定时器Timer

    定时器Timer:定时开启线程 代码示例: #定时开启线程 import time from threading import Timer def func(): print('时间同步') #1-3 ...

  10. linux内核符号表

    我们已经看到 insmod 如何对应共用的内核符号来解决未定义的符号. 表中包含了全局内 核项的地址 -- 函数和变量 -- 需要来完成模块化的驱动. 当加载一个模块, 如何由模块 输出的符号成为内核 ...