示例使用的是最新 SqlRepoEx 2.0.2

可在:https://github.com/AzThinker/SqlRepoEx2.0Demo

或:https://gitee.com/azthinker/SqlRepoEx2.0Demo

演示模块:GettingStartedNorthwind

1、新建一个控制台程序;

2、通过Nuget包管理,下载SqlRepoEx.MsSql.Static

3、根据Northwind数据库的 Orders、Customers、Employees三张表结构生成三个简单的同名类;

4、 创建初始方法,初始一个工厂类。

 /// <summary>
/// init
/// 创建初始方法,初始一个工厂类。
/// </summary>
static void Init()
{
// Set Connection String
string ConnectionString = "Data Source=(Local);Initial Catalog=Northwind;User ID=test;Password=test";
var connectionProvider = new ConnectionStringConnectionProvider(ConnectionString);
MsSqlRepoFactory.UseConnectionProvider(connectionProvider); // this Demo is POJO ,So Using SimpleWritablePropertyMatcher()。
// 本例中,使用的是简单类,所以用SimpleWritablePropertyMatcher()来操作属性。
MsSqlRepoFactory.UseWritablePropertyMatcher(new SimpleWritablePropertyMatcher());
}

5、为了演示JOIN 在 Orders类增加几个相关字段

(1)、关联Customers

  public string CompanyName { get; set; }

(2)、  关联Employees

  public string LastName { get; set; }

  public string FirstName { get; set; }

6、实例一个Orders仓储

   var repoCustomers = MsSqlRepoFactory.Create<Orders>();

7、使用 SqlRepoEx 建立一个联接查询

 var cust = repoCustomers.Query().Select(c => c.OrderID, c => c.CompanyName, c => c.FirstName, c => c.LastName, c => c.OrderDate)
.InnerJoin<Customers>()
.On<Customers>((r, l) => r.CustomerID == l.CustomerID, l => l.CompanyName)
.InnerJoin<Employees>()
.On<Employees>((k, q) => k.EmployeeID == q.EmployeeID, q => q.FirstName, q => q.LastName)
.Top();

8、此查询的实际 SQL 语句

Console.WriteLine(cust.Sql());

...

 SELECT TOP (10) [dbo].[Orders].[OrderID]
, [dbo].[Customers].[CompanyName]
, [dbo].[Employees].[FirstName]
, [dbo].[Employees].[LastName]
, [dbo].[Orders].[OrderDate]
FROM [dbo].[Orders]
INNER JOIN [dbo].[Customers]
ON [dbo].[Orders].[CustomerID] = [dbo].[Customers].[CustomerID]
INNER JOIN [dbo].[Employees]
ON [dbo].[Orders].[EmployeeID] = [dbo].[Employees].[EmployeeID];

9、查询结果

 /// <summary>
/// Join 演示
/// </summary>
public static void DoJoin()
{
var repoCustomers = MsSqlRepoFactory.Create<Orders>(); var cust = repoCustomers.Query().Select(c => c.OrderID, c => c.CompanyName, c => c.FirstName, c => c.LastName, c => c.OrderDate)
.InnerJoin<Customers>()
.On<Customers>((r, l) => r.CustomerID == l.CustomerID, l => l.CompanyName)
.InnerJoin<Employees>()
.On<Employees>((k, q) => k.EmployeeID == q.EmployeeID, q => q.FirstName, q => q.LastName)
.Top(); Console.WriteLine(cust.Sql()); foreach(var item in cust.Go())
{
Console.WriteLine($"{item.OrderID}\t{item.CompanyName}\t{item.FirstName}\t{item.LastName}\t{item.OrderDate};");
} }
 10258   Ernst Handel    Nancy   Davolio 1996-07-17 0:00:00;
10270 Wartian Herkku Nancy Davolio 1996-08-01 0:00:00;
10275 Magazzini Alimentari Riuniti Nancy Davolio 1996-08-07 0:00:00;
10285 QUICK-Stop Nancy Davolio 1996-08-20 0:00:00;
10292 Tradi??o Hipermercados Nancy Davolio 1996-08-28 0:00:00;
10293 Tortuga Restaurante Nancy Davolio 1996-08-29 0:00:00;
10304 Tortuga Restaurante Nancy Davolio 1996-09-12 0:00:00;
10306 Romero y tomillo Nancy Davolio 1996-09-16 0:00:00;
10311 Du monde entier Nancy Davolio 1996-09-20 0:00:00;
10314 Rattlesnake Canyon Grocery Nancy Davolio 1996-09-25 0:00:00;

轻量ORM-SqlRepoEx (六) JOIN的更多相关文章

  1. Dapper.NET——轻量ORM

    Dapper.NET使用 http://www.cnblogs.com/yankliu-vip/p/4182892.html 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Da ...

  2. SqlSugar轻量ORM

      蓝灯软件数据股份有限公司项目,代码开源. SqlSugar是一款轻量级的MSSQL ORM ,除了具有媲美ADO的性能外还具有和EF相似简单易用的语法. 学习列表 0.功能更新 1.SqlSuga ...

  3. Dapper.NET—轻量ORM

    Dapper.NET使用 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Dapper(4.0)为例. 2.1 在数据库中建立几张表. 2.2实体类. 3.使用方法 3.1  一 ...

  4. C# Dapper 轻量ORM调试对SQLServer

    Dapper简介 Dapper只有一个代码文件,完全开源,你可以放在项目里的任何位置,来实现数据到对象的ORM操作,体积小速度快. 使用ORM的好处是增.删.改很快,不用自己写sql,因为这都是重复技 ...

  5. 轻量ORM-SqlRepoEx介绍

    轻量级 ORM-SqlRepoEx 介绍 SqlRepoEx是 .Net平台下兼容.NET Standard 2.0人一个轻型的ORM.解决了Lambda转Sql语句这一难题,SqlRepoEx使用的 ...

  6. 轻量ORM-SqlRepoEx (九)与Dapper共舞

    Dapper就另一个轻量ORM,Dapper及其扩展解决了数据访问端的大部门问题,提供了如数据事务管理.缓存等支持.SqlRepoEx的重点解决了Lambda转换成SQL语句,使SQL使用强类型编写, ...

  7. 轻量型ORM框架Dapper的使用

    在真实的项目开发中,可能有些人比较喜欢写SQL语句,但是对于EF这种ORM框架比较排斥,那么轻量型的Dapper就是一个不错的选择,即让你写sql语句了,有进行了关系对象映射.其实对于EF吧,我说下我 ...

  8. CYQ.Data 轻量数据层之路 使用篇二曲 MAction 数据查询(十三)----002

    原文链接:https://blog.csdn.net/cyq1162/article/details/53303390 前言说明: 本篇继续上一篇内容,本节介绍所有相关查询的使用. 主要内容提要: 1 ...

  9. 编写轻量ajax组件01-对比webform平台上的各种实现方式

    前言 Asp.net WebForm 和 Asp.net MVC(简称MVC) 都是基于Asp.net的web开发框架,两者有很大的区别,其中一个就是MVC更加注重http本质,而WebForm试图屏 ...

随机推荐

  1. 移动web开发ajax缓存操作

    移动web开发过程中网速是必须考虑的一个因素,所以一般是尽可能的在本地存储数据,避免弱网环境下请求数据失败导致页面没有内容的情况. 前后端分离是web开发的必然趋势,在PC端我们有时甚至为了避免aja ...

  2. oracle数据库基本命令

    数据库字符集: SQL> select * from nls_database_parameters where parameter='NLS_CHARACTERSET'; PARAMETER ...

  3. OpenLayers中的图层(转载)

    作者:田念明出处:http://www.cnblogs.com/nianming/本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法 ...

  4. Scrapy框架Windows下安装

    在windows下安装好Python3 后,安装Scrapy也有许多种方法,我这里采用pip 安装.前提您已经安装了pip 直接在cmd命令行中 pip install Scrapy building ...

  5. [问题记录]libpomelo的安装

    1. 描述: 按照github上的操作完成 Windows in your libpomelo project root directory open git bash and type in mkd ...

  6. Docker_1 安装Docker-CE

    安装 免sudo运行docker命令 ustc mirrors service failed 安装 Docker-CE 安装过程参考官网,Ubuntu中如下: ## 1. 从仓库安装 $ sudo a ...

  7. 安装或删除Skype for business server组件的时候,报错"错误: 找不到 SQL 服务"

    安装或删除Skype for business server组件的时候,到了安装所有并置数据库的时候,报错“错误: 找不到 SQL 服务.确保计算机 skype.centos.com 中安装了 SQL ...

  8. shell脚本需求

    需求一:写一个脚本 1.设定变量FILE的值为/etc/passwd 2.依次向/etc/passwd中的每个用户问好,并且说出对方的ID是什么 形如:(提示:LINE=`wc -l /etc/pas ...

  9. 电池容量单位 Wh和 Ah的关系

    电池容量单位,应该是一个能量单位.我认为使用Wh,KWh比较科学. 功率单位是W 能量单位是WH 部分手机.充电宝使用Ah作为单位,需要通过电池输出电压进行单位转换. 转换公式 Ah * 电池输出电压 ...

  10. 如何在Windows 7/8/10中使用热键来调整音量?

    有时,您需要一个热键来调整Windows PC中的音量.例如:播放全屏视频或游戏时需要调整音量. 有一个简单的方法可以做到: 安装并运行Perfect Hotkey软件.   配置键盘快捷键以进行音量 ...