轻量ORM-SqlRepoEx (六) JOIN
示例使用的是最新 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的更多相关文章
- Dapper.NET——轻量ORM
Dapper.NET使用 http://www.cnblogs.com/yankliu-vip/p/4182892.html 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Da ...
- SqlSugar轻量ORM
蓝灯软件数据股份有限公司项目,代码开源. SqlSugar是一款轻量级的MSSQL ORM ,除了具有媲美ADO的性能外还具有和EF相似简单易用的语法. 学习列表 0.功能更新 1.SqlSuga ...
- Dapper.NET—轻量ORM
Dapper.NET使用 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Dapper(4.0)为例. 2.1 在数据库中建立几张表. 2.2实体类. 3.使用方法 3.1 一 ...
- C# Dapper 轻量ORM调试对SQLServer
Dapper简介 Dapper只有一个代码文件,完全开源,你可以放在项目里的任何位置,来实现数据到对象的ORM操作,体积小速度快. 使用ORM的好处是增.删.改很快,不用自己写sql,因为这都是重复技 ...
- 轻量ORM-SqlRepoEx介绍
轻量级 ORM-SqlRepoEx 介绍 SqlRepoEx是 .Net平台下兼容.NET Standard 2.0人一个轻型的ORM.解决了Lambda转Sql语句这一难题,SqlRepoEx使用的 ...
- 轻量ORM-SqlRepoEx (九)与Dapper共舞
Dapper就另一个轻量ORM,Dapper及其扩展解决了数据访问端的大部门问题,提供了如数据事务管理.缓存等支持.SqlRepoEx的重点解决了Lambda转换成SQL语句,使SQL使用强类型编写, ...
- 轻量型ORM框架Dapper的使用
在真实的项目开发中,可能有些人比较喜欢写SQL语句,但是对于EF这种ORM框架比较排斥,那么轻量型的Dapper就是一个不错的选择,即让你写sql语句了,有进行了关系对象映射.其实对于EF吧,我说下我 ...
- CYQ.Data 轻量数据层之路 使用篇二曲 MAction 数据查询(十三)----002
原文链接:https://blog.csdn.net/cyq1162/article/details/53303390 前言说明: 本篇继续上一篇内容,本节介绍所有相关查询的使用. 主要内容提要: 1 ...
- 编写轻量ajax组件01-对比webform平台上的各种实现方式
前言 Asp.net WebForm 和 Asp.net MVC(简称MVC) 都是基于Asp.net的web开发框架,两者有很大的区别,其中一个就是MVC更加注重http本质,而WebForm试图屏 ...
随机推荐
- 移动web开发ajax缓存操作
移动web开发过程中网速是必须考虑的一个因素,所以一般是尽可能的在本地存储数据,避免弱网环境下请求数据失败导致页面没有内容的情况. 前后端分离是web开发的必然趋势,在PC端我们有时甚至为了避免aja ...
- oracle数据库基本命令
数据库字符集: SQL> select * from nls_database_parameters where parameter='NLS_CHARACTERSET'; PARAMETER ...
- OpenLayers中的图层(转载)
作者:田念明出处:http://www.cnblogs.com/nianming/本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法 ...
- Scrapy框架Windows下安装
在windows下安装好Python3 后,安装Scrapy也有许多种方法,我这里采用pip 安装.前提您已经安装了pip 直接在cmd命令行中 pip install Scrapy building ...
- [问题记录]libpomelo的安装
1. 描述: 按照github上的操作完成 Windows in your libpomelo project root directory open git bash and type in mkd ...
- Docker_1 安装Docker-CE
安装 免sudo运行docker命令 ustc mirrors service failed 安装 Docker-CE 安装过程参考官网,Ubuntu中如下: ## 1. 从仓库安装 $ sudo a ...
- 安装或删除Skype for business server组件的时候,报错"错误: 找不到 SQL 服务"
安装或删除Skype for business server组件的时候,到了安装所有并置数据库的时候,报错“错误: 找不到 SQL 服务.确保计算机 skype.centos.com 中安装了 SQL ...
- shell脚本需求
需求一:写一个脚本 1.设定变量FILE的值为/etc/passwd 2.依次向/etc/passwd中的每个用户问好,并且说出对方的ID是什么 形如:(提示:LINE=`wc -l /etc/pas ...
- 电池容量单位 Wh和 Ah的关系
电池容量单位,应该是一个能量单位.我认为使用Wh,KWh比较科学. 功率单位是W 能量单位是WH 部分手机.充电宝使用Ah作为单位,需要通过电池输出电压进行单位转换. 转换公式 Ah * 电池输出电压 ...
- 如何在Windows 7/8/10中使用热键来调整音量?
有时,您需要一个热键来调整Windows PC中的音量.例如:播放全屏视频或游戏时需要调整音量. 有一个简单的方法可以做到: 安装并运行Perfect Hotkey软件. 配置键盘快捷键以进行音量 ...