RavenDb学习(五)结果转换
)Result Transformers
public class Order
{
public DateTime OrderedAt { get; set; }
public Status Status { get; set; }
public string CustomerId { get; set; }
public IList<OrderLine> Lines { get; set; }
}
//单独使用
public class OrderStatisticsTransformer : AbstractTransformerCreationTask<Order>
{
public OrderStatisticsTransformer()
{
TransformResults = orders => from order in orders
select new
{
order.OrderedAt,
order.Status,
order.CustomerId,
CustomerName = LoadDocument<Customer>(order.CustomerId).Name,
LinesCount = order.Lines.Count
};
}
}
public class OrderStatistics
{
public DateTime OrderedAt { get; set; }
public Status Status { get; set; }
public string CustomerId { get; set; }
public string CustomerName { get; set; }
public int LinesCount { get; set; }
}
//配合查询使用
IList<OrderStatistics> statistics = session.Query<Order>()
.TransformWith<OrderStatisticsTransformer, OrderStatistics>()
.Where(x => x.CustomerId == "customers/1")
.ToList();
OrderStatistics statistic = session.Load<OrderStatisticsTransformer, OrderStatistics>("orders/1");
) OfType<T>
OfType<T>是在客户端进行数据转换
比如说我们有一个这样的索引:
public class Product_ByQuantity : AbstractIndexCreationTask<Product>
{
public Product_ByQuantity()
{
Map = products => from product in products
select new
{
QuantityInWarehouse = product.QuantityInWarehouse
};
TransformResults = (database, results) => from r in results
select new
{
Name = r.Name,
Description = r.Description
};
}
}
产品类:
public class Product
{
public string Id { get; set; }
public string ArticleNumber { get; set; }
public string Name { get; set; }
public string Manufacturer { get; set; }
public string Description { get; set; }
public int QuantityInWarehouse { get; set; }
}
返回结果类:
public class ProductViewModel
{
public string Name { get; set; }
public string Description { get; set; }
}
查询的之后,进行转换
List<ProductViewModel> products = session.Query<Product, Product_ByQuantity>()
.Where(x => x.QuantityInWarehouse > )
.OfType<ProductViewModel>()
.ToList();
)ProjectFromIndexFieldsInto
这是map-only的索引
public class Product_ByQuantityNameAndDescription : AbstractIndexCreationTask<Product>
{
public Product_ByQuantityNameAndDescription()
{
Map = products => from product in products
select new
{
QuantityInWarehouse = product.QuantityInWarehouse,
Name = product.Name,
Description = product.Description
};
Stores.Add(x => x.Name, FieldStorage.Yes);
Stores.Add(x => x.Description, FieldStorage.Yes);
}
}
//查询
List<ProductViewModel> products = session.Query<Product, Product_ByQuantityNameAndDescription>()
.Where(x => x.QuantityInWarehouse > )
.ProjectFromIndexFieldsInto<ProductViewModel>()
.ToList();
)客户端转换
索引的定义:
public class Product_ById : AbstractIndexCreationTask<ProductItem>
{
public Product_ById()
{
Map = products => from product in products
select new
{
product.Id
};
}
}
var warehouses = session.Query<dynamic, Product_ById>()
.Customize(x => x.TransformResults((query, results) =>
results.Cast<dynamic>().GroupBy(p => p.WarehouseId).Select(g =>
{
;
;
var products = g.Select(product =>
{
count++;
totalSum += product.Price;
return new ProductItemViewModel
{
Name = product.Name,
Description = product.Description
};
}).ToList();
return new Warehouse()
{
Id = g.Key,
Products = products,
AverageProductPrice = totalSum / count,
};
}))).ToList();
RavenDb学习(五)结果转换的更多相关文章
- cesium 学习(五) 加载场景模型
cesium 学习(五) 加载场景模型 一.前言 现在开始实际的看看效果,目前我所接触到基本上都是使用Cesium加载模型这个内容,以及在模型上进行操作.So,现在进行一些加载模型的学习,数据的话可以 ...
- C# 词法分析器(五)转换 DFA
系列导航 (一)词法分析介绍 (二)输入缓冲和代码定位 (三)正则表达式 (四)构造 NFA (五)转换 DFA (六)构造词法分析器 (七)总结 在上一篇文章中,已经得到了与正则表达式等价的 NFA ...
- TweenMax动画库学习(五)
目录 TweenMax动画库学习(一) TweenMax动画库学习(二) TweenMax动画库学习(三) Tw ...
- SVG 学习<五> SVG动画
目录 SVG 学习<一>基础图形及线段 SVG 学习<二>进阶 SVG世界,视野,视窗 stroke属性 svg分组 SVG 学习<三>渐变 SVG 学习<四 ...
- Android JNI学习(五)——Demo演示
本系列文章如下: Android JNI(一)——NDK与JNI基础 Android JNI学习(二)——实战JNI之“hello world” Android JNI学习(三)——Java与Nati ...
- ZigBee学习五 无线温度检测
ZigBee学习五 无线温度检测 1)修改公用头文件GenericApp.h typedef union h{ uint8 TEMP[4]; struct RFRXBUF { unsigned cha ...
- (转)MyBatis框架的学习(五)——一对一关联映射和一对多关联映射
http://blog.csdn.net/yerenyuan_pku/article/details/71894172 在实际开发中我们不可能只是对单表进行操作,必然要操作多表,本文就来讲解多表操作中 ...
- Python基础学习五
Python基础学习五 迭代 for x in 变量: 其中变量可以是字符串.列表.字典.集合. 当迭代字典时,通过字典的内置函数value()可以迭代出值:通过字典的内置函数items()可以迭代出 ...
- Java IO流学习总结五:转换流-InputStreamReader、OutputStreamWriter
类的继承关系 Reader |__ BufferedReader.StringReader.InputStreamReader |__ FileReader Writer |__ BufferedWr ...
随机推荐
- Python 爬虫 使用正则去掉不想要的网页元素
在做爬虫的时候,我们总是不想去看到网页的注释,或者是网页的一些其他元素,有没有好的办法去掉他们呢? 例如:下面的问题 第一种情况<ahref="http://artso.artron. ...
- Linux中用户及用户组
Linux用户只有两个等级:root及非root.Linux中还有一部分用户,如:apache.mysql.nobody.ftp等,这些也都是非root用户,即普通用户.Linux的权限实际是上不同用 ...
- SpringBoot actuator 应用监控。
前言 : 今天在阅读 <SpringCloud微服务实战>一书时看到了SpringBoot actuator相关知识,并且自己也本地调试实践.觉得SpringBoot这一套监控还是挺有意思 ...
- Gradle 1.12用户指南翻译
http://blog.csdn.net/maosidiaoxian/article/category/2219983
- openvpn 的安装和使用
这里我参考的文章有 OpenVpn https://my.oschina.net/mn1127/blog/855842http://linuxchina.blog.51cto.com/938835/1 ...
- Java:多线程,Exchanger同步器
1. 背景 类java.util.concurrent.Exchanger提供了一个同步点,在这个同步点,一对线程可以交换数据.每个线程通过exchange()方法的入口提供数据给他的伙伴线程,并接收 ...
- 揭秘QQ 安全password框的原理
这篇文章也算是朝花夕拾.事实上非常早曾经就知道的原理,如今拿出来和大家交流分享一下. 故事总要有缘由.那么这个故事的缘由就是,当我曾经写了一个获取其他进程password框password的时候(前几 ...
- 【Unity】7.4 游戏外设输入
分类:Unity.C#.VS2015 创建日期:2016-04-21 一.简介 Unity可以处理摇杆.游戏手柄.方向盘等标准游戏外设的输入,使用的方法如下图所示: 虚拟按键需要在输入管理器中配置,把 ...
- AWS产品目录
计算 Amazon EC2:弹性虚拟机 AWS Batch:批处理计算 Amazon ECR:Docker容器管理 Amazon ECS:高度可扩展的快速容器管理服务 Amazon EKS:在AWS上 ...
- 每日英语:Three Shows That Changed The Way Networks Think About Viewership
As we continue examining this season’s DVR success stories in The Blacklist and Sleepy Hollow it mak ...