atitit. 集合groupby 的实现(2)---自己定义linq查询--java .net php
atitit. 集合groupby 的实现(2)---自己定义linq查询--java .net php
实现方式有例如以下
5. Groupby分组方法 code----groupBy() 4
做报表统计啊。有个大问题。。
有人整过集合的groupby查询汇总(Sum)没有哟??已经使用了linq4j,quaere,josql。,ms 对Map字典不起作用。
。
1. Linq的实现原理流程(ati总结)
全部的统计函数都是对查询出的每一行数据进行分类以后再进行统计计算。所以在结果集合中,对所进行分类的列的每一种数据都有一行统计结果值与之相应。
聚合结果是针对每个分组,而不是整个表
从技术上来说,能够使用不带不论什么聚合函数的GROUP BY子句,但这种语句可能毫无意义。
要将全部行分组, 必需要对全部的行运行操作,
Process pic as flow..(PDA pic)
grpBy()
Union>>>grpTAb1>>> sum() .leftjoin( count()) .leftjoin (avg());
Union>>>grpTAb22 >>sum() .leftjoin( count()) .leftjoin (avg());
Filter Outpu();
作者::老哇的爪子Attilax艾龙。EMAIL:1466519819@qq.com
转载请注明来源:http://blog.csdn.net/attilax
2. groupby 与事先排序
一些程序的groupby 操作 api须要数据事先排序..而实际上,这个不是必须的..
Excel的groupby就要事先排序的
3. #----------聚合函数
聚合函数分为两类,,,,单行函数和多行函数。多行函数也叫聚合函数、组合函数。
。聚合函数的參数为数组
在java8 JDK包括很多聚合操作(如平均值。总和,最小,最大。和计数),返回一个计算流stream的聚合结果。这些聚合操作被称为聚合操作。
JDK除返回单个 值的聚合操作外。还有非常多聚合操作返回一个collection集合实例。非常多的reduce操作运行特定的任务,如求平均值或按类别分组元素。
#-----------通用的聚合操作:Stream.reduce,Stream.collection
JDK提供的通用的聚合操作:Stream.reduce,Stream.collection
注意:本文将reduction operations翻译为聚合操作,由于reduction operations通经常使用于汇聚统计。
两者的差别:
Stream.reduce,经常使用的方法有average, sum, min, max, and count。返回单个的结果值。而且reduce操作每处理一个元素总是创建一个新值
Stream.collection与stream.reduce方法不同。Stream.collect改动现存的值,而不是每处理一个元素,创建一个新值
#--------特定用途的汇聚操作
Stream接口有一些通用的汇聚操作,比方reduce()和collect();也有一些特定用途的汇聚操作,比方sum(),max()和count()
4. 自己定义linq查询Linq .from(li) .groupBy("url","user" ) .select("url", count().as("countx"), avg("len").as("avgx")); avg("len").as("avgx"));
public static void main(String[] args) { // throws QueryParseException,
// QueryExecutionException {
// attilax 老哇的爪子 0_52_g o8d
List li = new ArrayList<Map>() {
{
this.add(new HashMap() {
{
put("url", "url1");
put("user", "u1");
);
}
});
this.add(new HashMap() {
{
put("url", "url1");
);
put("user", "u2");
}
});
this.add(new HashMap() {
{
put("url", "url2");
);
put("user", "u1");
}
});
}
};
List li2 = Linq
.from(li)
.groupBy("url","user" )
.select("url", count().as("countx"),
avg("len").as("avgx"));
core.print_wzFmt(li2);
结果:::
[
{
"avgx": null,
"countx": 1,
"url": "url1"
},
{
"avgx": null,
"countx": 1,
"url": "url1"
},
{
"avgx": null,
"countx": 1,
"url": "url2"
}
]
5. Groupby分组方法 code----groupBy()
public Linq groupBy(final String... fld) {
// attilax 老哇的爪子 l_39_39 o8d
this.grpby_flds = fld;
CollectionUtils.each(this.li, new Closure<Map, Object>() {
@Override
public Object execute(Map m) throws Exception {
// attilax 老哇的爪子 m_4_41 o8d
Val v = Mapx.$(m).get(fld);
// if(createGrp(m.get(fld)))
String key = v.toString();
if (grpbyRztLi_MpFmt.get(key) == null)
grpbyRztLi_MpFmt.put(key, new GroupTable());
GroupTable gt = grpbyRztLi_MpFmt.get(key);
gt.grpby_fld = fld;
gt.key = v;
gt.add(m);
return null;
}
});
return this;
}
6. 实现聚合操作select()
public List select(final Object... slktObj) {
// attilax 老哇的爪子 l_46_a o8d
// list union
List lix = CollectionUtils.each_RE(grpbyRztLi_MpFmt,
new Closure<Entry<Object, GroupTable>, Object>() {
@Override
public Object execute(Entry<Object, GroupTable> e)
throws Exception {
// attilax 老哇的爪子 0_e_47 o8e
List<Map> singTab = e.getValue().li;
List<reduceCalcRzt_singleExprs> li = new ArrayList<>();
for (Object o : slktObj) {
if (o instanceof Iredus) {
Iredus ci = (Iredus) o;
reduceCalcRzt_singleExprs rzt_se = ci
.exec(singTab);
li.add(rzt_se);
filtOutputFlds.add(ci.getOutputColname());
} else {
filtOutputFlds.add(o.toString());
}
}
reduceCalcRecord rcr = redusUtil.leftjoin(li);
));
return rcr.map;
}
});
//filt fld to output
List li2 = CollectionUtils.each_NS(lix, new Closure<Map, Map>() {
@Override
public Map execute(Map arg0) throws Exception {
// attilax 老哇的爪子 12:29:50 AM Aug 17, 2014
final Map m = new HashMap();
CollectionUtils.each_RE(arg0, new Closure<Entry, Object>() {
@Override
public Object execute(Entry e) throws Exception {
// attilax 老哇的爪子 12:33:21 AM Aug 17, 2014
String k = e.getKey().toString();
if (filtOutputFlds.contains(k))
m.put(k, e.getValue());
return null;
}
});
return m;
}
});
return li2;
}
7. Count,sum()的实现
public class countImp
@Override
public reduceCalcRzt_singleExprs exec(final List GroupTable ) {
// attilax 老哇的爪子 10:16:21 PM Aug 16, 2014
reduceCalcRzt_singleExprs o=new reduceCalcRzt_singleExprs();
o.map=new HashMap(){
{
put(colName,GroupTable.size());
}
};
{
return o;
}
}
8. 參考
Java8怎样进行stream,reduce,collection操作 - 51CTO.COM.htm
Java并没没落:最新Java 8简明教程译文(3) - 51CTO.COM.htm
atitit. 集合groupby 的实现(2)---自己定义linq查询--java .net php的更多相关文章
- atitit. 集合groupby 的实现(2)---自定义linq查询--java .net php
atitit. 集合groupby 的实现(2)---自定义linq查询--java .net php 实现方式有如下 1. Linq的实现原理流程(ati总结) 1 2. groupby 与 事 ...
- atitit.集合的filt操作细分 filter总结
atitit.集合的filt操作细分 filter总结 1. Css sltr 1 2. 基本选择器(根据id,class,元素名) 2 3. 层次选择器 3 4. 过滤选择器 3 5. First, ...
- Atitit usbQb212 oo 面向对象封装的标准化与规范解决方案java c# php js
Atitit usbQb212 oo 面向对象封装的标准化与规范解决方案java c# php js 1.1. 封装性是面象对象编程中的三大特性之一 三个基本的特性:封装.继承与多态1 1.2. 魔 ...
- LINQ查询操作符之Select、Where、OrderBy、OrderByDescending、GroupBy、Join、GroupJoin及其对应的查询语法
介绍 ·Select - Select选择:延迟 ·Where - Where查询:延迟 ·OrderBy - 按指定表达式对集合正序排序:延迟 ·OrderByDescend ...
- C#高级知识点概要(3) - 特性、自动属性、对象集合初始化器、扩展方法、Lambda表达式和Linq查询
1.特性(Attributes) 特性(Attributes),MSDN的定义是:公共语言运行时允许你添加类似关键字的描述声明,叫做attributes, 它对程序中的元素进行标注,如类型.字段.方法 ...
- Atitit 数据库视图与表的wrap与层级查询规范
Atitit 数据库视图与表的wrap与层级查询规范 1.1. Join层..连接各个表,以及显示各个底层字段1 1.2. 统计层1 1.3. 格式化层1 1.1. Join层..连接各个表,以及显示 ...
- Linq查询datatable的记录集合
通过linq查询datatable数据集合满足条件的数据集 1.首先定义查询字段的变量,比方深度 string strDepth=查询深度的值: var dataRows = from datarow ...
- atitit.人脸识别的应用场景and使用最佳实践 java .net php
atitit.人脸识别的应用场景and使用最佳实践 java .net php 1. 人脸识别的应用场景 1 2. 框架选型 JNI2OpenCV.dll and JavaCV 1 3. Url ap ...
- Linq 查询 List集合
总是听到身边的同事说起Linq ,知道上学的时候学过,可是自从毕业之后就再也没用过,总觉得是很牛的技能 ,可是当自己真正学会用的时候才发现,我去,So easy .废话不多说直接上代码吧 var li ...
随机推荐
- java 物理分页和逻辑分页
A.逻辑分页利用游标分页,好处是所有数据库都统一,坏处就是效率低.1.逻辑分页的第一种方式,利用ResultSet的滚动分页.这种分页方式依靠的是对结果集的算法来分页,因此通常被称为“逻辑分页”.步骤 ...
- MFC_2.1使用单选和多选框
使用单选和多选框 单选 1.拖控件 设置名字,CTRL+D设置顺序,属性设置第一个GROUP为TRUE: 2.设置第一个按钮绑定变量为 值 INT型 名称m_RadioIndxe; 3.设置单击响应内 ...
- spring 实例 bean 的方式
一.使用构造器实例化: <bean id="personService" class="cn.mytest.service.impl.PersonServiceBe ...
- pageHelper详解
详见:https://github.com/pagehelper/Mybatis-PageHelper/edit/master/wikis/zh/HowToUse.md ## 使用方法 1. 引入分页 ...
- java学习_5_21
数组的插入.删除.扩容本质上都是用的数组的复制.Java中数组的拷贝如下: System.arraycopy(Object src, int srcPos, Object dest, int dest ...
- CMU Database Systems - Two-phase Locking
首先锁是用来做互斥的,解决并发执行时的数据不一致问题 如图会导致,不可重复读 如果这里用lock就可以解决,数据库里面有个LockManager来作为master,负责锁的记录和授权 数据库里面的基本 ...
- PMP 学习心得
前两天刚考完 PMP,松了一口气,终于考完了,虽然心里有点慌,不知道自己会不会过.学习 PMP 这三个月还是很充实的.不断的看视频,做题目,功夫不负有心人,也算是学到了一些东西.至少知道了一个项目的启 ...
- Python常用的内建模块
PS:Python之所以自称“batteries included”,就是因为内置了许多非常有用的模块,无需额外安装和配置,即可直接使用.下面就来看看一些常用的内建模块. 参考原文 廖雪峰常用的内建模 ...
- 在MONO Design中使用Flex3D
在项目开发组的努力下,HTML5 3D 的开发包变得越来越优秀,越来越健壮:基于HTML5 3D技术的MONO Design建模平台功能也变得越来越强大和完善,这个方便了很多使用我们HTML5 3D的 ...
- HDU - 5952 Counting Cliques(dfs搜索)
题目: A clique is a complete graph, in which there is an edge between every pair of the vertices. Give ...