轻量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试图屏 ...
随机推荐
- 谈谈HTML5中的history.pushSate方法,弥补ajax导致浏览器前进后退无效的问题
移动端为了减少页面请求,有时候需要通过单页面做成多页面的效果,最近有这么个需求,表单填完后执行第一步,然后执行第二步,第二步执行完后再执行第三步,每一步都要保留之前的数据.这种情况用单页面实现再合适不 ...
- 关于纯css写三角形在firefox下的锯齿问题
相信很多人都用过利用border来实现小三角箭头,百度一下,这类的文章多如牛毛,这里我还是啰嗦点把常用的方法陈列出来: .triangle_border_up{ width:; height:; bo ...
- C++ VS编译问题--VS下生成DLL,但没有生成Lib的解决办法
如果项目生成了.dll文件,但是没有生成.lib文件,这是由于项目的设置错误,应作如下修改: 项目->属性->链接器->输入->模块定义文件,设置你的模块定义文件,默认为lib ...
- 09_dubbo服务发布原理
[ 启动服务的日志分析 ] 1.暴露本地服务 Export dubbo service com.alibaba.dubbo.demo.DemoService to local registry, du ...
- Java类——JDBC链接、并操作MySQL数据库
Java——MySQL数据库操作类 package pkg.src.database; import java.sql.*; public class MYSQL_DBManager { // //定 ...
- #学习tips——写给自己的语录
用编程证明自己的观点! "我以为我懂了?"-- 花1/3的时间去学去记,剩下的时间应用做记忆实战. 记录一个转变 2018.6.7 (英文字幕-->无字幕!)good job ...
- <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
viewport:移动设备上用来显示网页的那部分区域,但其大小并不局限于那部分可视区域 width设置layout viewport 的宽度,为一个正整数,或字符串"device-widt ...
- arm汇编学习(三)
一.ndk编译android上运行的c程序 新建个hello目录,底下要有jni目录,下面就是Android.mk文件 1.Android.mk文件内容如下: LOCAL_PATH:= $(call ...
- QT开发(二) windows下简单部署
如果使用vs编译器 需要c runtime 例如(msvc110 )这种 还需要若干qt的dll 基本在qt的bin目录 如果使用了QWindow这种对象还需要引用qt目录 plugins下 的内容 ...
- UVaOJ 694 - The Collatz Sequence
题目很简单,但是一开始却得到了Time Limit的结果,让人感到很诧异.仔细阅读发现,题目中有一个说明: Neither of these, A or L, is larger than 2,147 ...