轻量ORM-SqlRepoEx (三)Select语句
一、示例用数据库为Northwind数据库,可在百度网盘下载
https://pan.baidu.com/s/1er0Mm48kUfeAsYkSW6DfnA 密码:r7pm
二、如何初始化SqlRepoEx请参看上一篇博文《轻量ORM-SqlRepoEx (二)初始化SqlRepoEx》
三、生成示例用类
public class Customers
{
#region 业务属性定义 public string CustomerID { get; set; } public string CompanyName { get; set; } public string ContactName { get; set; } public string ContactTitle { get; set; } public string Address { get; set; } public string City { get; set; } public string Region { get; set; } public string PostalCode { get; set; } public string Country { get; set; } public string Phone { get; set; } public string Fax { get; set; } #endregion
}
四、一个简单的Select调用
var repository = RepoFactory.Create<Customers>();
var results = repository.Query()
.Select(e => e.CustomerID, e => e.ContactName, e => e.CompanyName)
.OrderBy(e => e.CustomerID)
.Top(20)
.Go();
foreach (var item in results)
{
Console.WriteLine($"{item.CustomerID}\t {item.ContactName}\t\t {item.CompanyName} ");
}
得到如下结果:
ALFKI Maria Anders Alfreds Futterkiste
ANATR Ana Trujillo Ana Trujillo Emparedados y helados
ANTON Antonio Moreno Antonio Moreno Taquería
AROUT Thomas Hardy Around the Horn
BERGS Christina Berglund Berglunds snabbk?p
BLAUS Hanna Moos Blauer See Delikatessen
BLONP Frédérique Citeaux Blondesddsl père et fils
BOLID Martín Sommer Bólido Comidas preparadas
BONAP Laurence Lebihan Bon app'
BOTTM Elizabeth Lincoln Bottom-Dollar Markets
BSBEV Victoria Ashworth B's Beverages
CACTU Patricio Simpson Cactus Comidas para llevar
CENTC Francisco Chang Centro comercial Moctezuma
CHOPS Yang Wang Chop-suey Chinese
COMMI Pedro Afonso Comércio Mineiro
CONSH Elizabeth Brown Consolidated Holdings
DRACD Sven Ottlieb Drachenblut Delikatessen
DUMON Janine Labrune Du monde entier
EASTC Ann Devon Eastern Connection
ERNSH Roland Mendel Ernst Handel
如果需要打印当前查询的SQL语句,而不是运行只需要调用Sql():
var results2 = repository.Query()
.Select(e => e.CustomerID, e => e.ContactName, e => e.CompanyName)
.OrderBy(e => e.CustomerID)
.Top(20)
.Sql();
得到如下结果:
SELECT TOP (20) [dbo].[Customers].[CustomerID]
, [dbo].[Customers].[ContactName]
, [dbo].[Customers].[CompanyName]
FROM [dbo].[Customers]
ORDER BY [dbo].[Customers].[CustomerID] ASC;
四、Select
1、实例一个查询实例的Repository
2、调用Repository 的Query() 获取一个查询类SelectStatement实例,此类实现大多数SQL查询场景;
3、SelectStatement有两个重要的方法
(1)、Sql()方法,此方法会返回当前repository.Query()的实际SQL语句;
(2)、Go()方法,此方法可将当前Select返回一个IEnumerable<TEntity>结果,另外,SelectStatement还实现了 ListEntityGo<TLEntity>()方法,返回一个List<TEntity>;
4、repository.Query()可简单的调用 repository.Query().Go(),这样会返回完整的实例集;其效果与repository.Query().SelectAll().Go();是一样的,但SelectAll()可以指定当前查询别名。、;
5、如果只需要返回数据集的部分字段数据,可以采用Select(e => e.CustomerID, e => e.ContactName, e => e.CompanyName)的表达示来获取特定列的数据;
轻量ORM-SqlRepoEx (三)Select语句的更多相关文章
- SqlSugar轻量ORM
蓝灯软件数据股份有限公司项目,代码开源. SqlSugar是一款轻量级的MSSQL ORM ,除了具有媲美ADO的性能外还具有和EF相似简单易用的语法. 学习列表 0.功能更新 1.SqlSuga ...
- Dapper.NET——轻量ORM
Dapper.NET使用 http://www.cnblogs.com/yankliu-vip/p/4182892.html 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Da ...
- Dapper.NET—轻量ORM
Dapper.NET使用 本文目录 Dapper.NET使用 1.为什么选择Dapper 2.以Dapper(4.0)为例. 2.1 在数据库中建立几张表. 2.2实体类. 3.使用方法 3.1 一 ...
- PL/SQL轻量版(三)——游标与异常处理
一.游标 1.概念 游标是一个 指向上下文的句柄( handle) 或指针.通过游标,PL/SQL 可以控制上下文区和处理语句时上下文区会发生些什么事情. 2.游标处理 处理显式游标 主要包含以下四个 ...
- MySQL8.0关系数据库基础教程(三)-select语句详解
1 查询指定字段 在 employee 表找出所有员工的姓名.性别和电子邮箱. SELECT 表示查询,随后列出需要返回的字段,字段间逗号分隔 FROM 表示要从哪个表中进行查询 分号为语句结束符 这 ...
- C# Dapper 轻量ORM调试对SQLServer
Dapper简介 Dapper只有一个代码文件,完全开源,你可以放在项目里的任何位置,来实现数据到对象的ORM操作,体积小速度快. 使用ORM的好处是增.删.改很快,不用自己写sql,因为这都是重复技 ...
- 轻量ORM-SqlRepoEx (四)INSERT、UPDATE、DELETE 语句
*本文中所用类声明见上一篇博文<轻量ORM-SqlRepoEx (三)Select语句>中Customers类 一.增加记录 1.工厂一个实例仓储 var repository = Rep ...
- 轻量ORM-SqlRepoEx介绍
轻量级 ORM-SqlRepoEx 介绍 SqlRepoEx是 .Net平台下兼容.NET Standard 2.0人一个轻型的ORM.解决了Lambda转Sql语句这一难题,SqlRepoEx使用的 ...
- 轻量ORM-SqlRepoEx (九)与Dapper共舞
Dapper就另一个轻量ORM,Dapper及其扩展解决了数据访问端的大部门问题,提供了如数据事务管理.缓存等支持.SqlRepoEx的重点解决了Lambda转换成SQL语句,使SQL使用强类型编写, ...
随机推荐
- AtCoder Grand Contest 023 E - Inversions
Description 给出长度为 \(n\) 序列 \(A_i\),求出所有长度为 \(n\) 的排列 \(P\),满足 \(P_i<=A_i\),求所有满足条件的 \(P\) 的逆序对数之和 ...
- [转]<加密算法c#>——— 3DES加密之ECB模式 和 CBC模式
本文转自:http://www.cnblogs.com/qq278360339/archive/2013/06/05/3119222.html 最近 一个项目.net 要调用JAVA的WEB SERV ...
- Java Mail邮件发送的简单实现
1.什么是java mail JAVA MAIL是利用现有的邮件账户发送邮件的工具,通过JAVA Mail的操控,让程序自动的使用设置的邮箱发送邮件. 这一机制被广泛的用在注册激活和垃圾邮件的发送等方 ...
- OLEDB 调用存储过程
除了常规调用sql语句和进行简单的插入删除操作外,OLEDB还提供了调用存储过程的功能,存储过程就好像是用SQL语句写成的一个函数,可以有参数,有返回值. 存储过程除了像普通函数那样返回一般的值以外, ...
- 一个基于Ionic3.x cordova的移动APP demo
项目地址如遇网络不佳,请移步国内镜像加速节点 前端技术: Angular4.x + ionic3.x + cordova 项目运行: git clone git@github.com:EasyTuan ...
- Daily paper -Science 2006: Experimental Study of Inequality and Unpredictability in an Artificial Cultural Market (探究群体行为对商品销量的影响)
论文: Experimental Study of Inequality and Unpredictability in an Artificial Cultural Market 发表期刊 ...
- html-表单的设计
一.表单的设计 1.注册表单页面 <html> <head> <title>表单的练习</title> <script> function ...
- php 获取毫秒时间戳
function getMsec(){//返回毫秒时间戳 $arr = explode(' ',microtime()); $hm = 0; foreach($arr as $v){ $hm += f ...
- 如何使用Putty登录安装在VirtualBox里的ubuntu
我是在Windows操作系统里用VirtualBox安装了ubuntu操作系统. 在VirtualBox里操作ubuntu的终端不是很方便,比如我想在Windows里复制一些命令到ubuntu的终端执 ...
- CRM中间件里的CSA队列有什么用
我们有时候会在中间件的事务码SMQ2即Inbound队列查看器里观察到以CSA开头的队列: 这些队列的作用是什么呢?在SAP community上已经有很多朋友提出了相同的问题,也有专家在下列两个连接 ...