- 浏览: 469425 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
mrshen:
很棒,在其他大神的博客上理清了思路看懂之后,来lz这里用例子学 ...
RED-BLACK(红黑)树的实现TreeMap源码阅读 -
a939639017:
yanf4j check不下来 ?
Java nio 2.0 AIO -
hellostory:
又是抄来的 - -
mysql分表方案 -
davidluoye:
为什么不说下支持的数据库呢?
模糊查询的优化 -
oliveevilo:
表示没看懂
Synchronized和java.util.concurrent.locks.Lock的区别
分组取最大
- --按某一字段分组取最大(小)值所在行的数据(2007-10-23于浙江杭州)
- /*
- 数据如下:
- name val memo
- a 2 a2(a的第二个值)
- a 1 a1--a的第一个值
- a 3 a3:a的第三个值
- b 1 b1--b的第一个值
- b 3 b3:b的第三个值
- b 2 b2b2b2b2
- b 4 b4b4
- b 5 b5b5b5b5b5
- */
- --创建表并插入数据:
- create table tb(name varchar(10),val int,memo varchar(20))
- insert into tb values('a', 2, 'a2(a的第二个值)')
- insert into tb values('a', 1, 'a1--a的第一个值')
- insert into tb values('a', 3, 'a3:a的第三个值')
- insert into tb values('b', 1, 'b1--b的第一个值')
- insert into tb values('b', 3, 'b3:b的第三个值')
- insert into tb values('b', 2, 'b2b2b2b2')
- insert into tb values('b', 4, 'b4b4')
- insert into tb values('b', 5, 'b5b5b5b5b5')
- go
- --一、按name分组取val最大的值所在行的数据。
- --方法1:
- select a.* from tb a where val = (select max(val) from tb where name = a.name) order by a.name
- --方法2:
- select a.* from tb a where not exists(select 1 from tb where name = a.name and val > a.val)
- --方法3:
- select a.* from tb a,(select name,max(val) val from tb group by name) b where a.name = b.name and a.val = b.val order by a.name
- --方法4:
- select a.* from tb a inner join (select name , max(val) val from tb group by name) b on a.name = b.name and a.val = b.val order by a.name
- --方法5
- select a.* from tb a where 1 > (select count(*) from tb where name = a.name and val > a.val ) order by a.name
- /*
- name val memo
- ---------- ----------- --------------------
- a 3 a3:a的第三个值
- b 5 b5b5b5b5b5
- */
- --二、按name分组取val最小的值所在行的数据。
- --方法1:
- select a.* from tb a where val = (select min(val) from tb where name = a.name) order by a.name
- --方法2:
- select a.* from tb a where not exists(select 1 from tb where name = a.name and val < a.val)
- --方法3:
- select a.* from tb a,(select name,min(val) val from tb group by name) b where a.name = b.name and a.val = b.val order by a.name
- --方法4:
- select a.* from tb a inner join (select name , min(val) val from tb group by name) b on a.name = b.name and a.val = b.val order by a.name
- --方法5
- select a.* from tb a where 1 > (select count(*) from tb where name = a.name and val < a.val) order by a.name
- /*
- name val memo
- ---------- ----------- --------------------
- a 1 a1--a的第一个值
- b 1 b1--b的第一个值
- */
- --三、按name分组取第一次出现的行所在的数据。
- select a.* from tb a where val = (select top 1 val from tb where name = a.name) order by a.name
- /*
- name val memo
- ---------- ----------- --------------------
- a 2 a2(a的第二个值)
- b 1 b1--b的第一个值
- */
- --四、按name分组随机取一条数据。
- select a.* from tb a where val = (select top 1 val from tb where name = a.name order by newid()) order by a.name
- /*
- name val memo
- ---------- ----------- --------------------
- a 1 a1--a的第一个值
- b 5 b5b5b5b5b5
- */
- --五、按name分组取最小的两个(N个)val
- select a.* from tb a where 2 > (select count(*) from tb where name = a.name and val < a.val ) order by a.name,a.val
- select a.* from tb a where val in (select top 2 val from tb where name=a.name order by val) order by a.name,a.val
- select a.* from tb a where exists (select count(*) from tb where name = a.name and val < a.val having Count(*) < 2) order by a.name
- /*
- name val memo
- ---------- ----------- --------------------
- a 1 a1--a的第一个值
- a 2 a2(a的第二个值)
- b 1 b1--b的第一个值
- b 2 b2b2b2b2
- */
- --六、按name分组取最大的两个(N个)val
- select a.* from tb a where 2 > (select count(*) from tb where name = a.name and val > a.val ) order by a.name,a.val
- select a.* from tb a where val in (select top 2 val from tb where name=a.name order by val desc) order by a.name,a.val
- select a.* from tb a where exists (select count(*) from tb where name = a.name and val > a.val having Count(*) < 2) order by a.name
- /*
- name val memo
- ---------- ----------- --------------------
- a 2 a2(a的第二个值)
- a 3 a3:a的第三个值
- b 4 b4b4
- b 5 b5b5b5b5b5
- */
评论
2 楼
dotjar
2011-03-21
28和30行的方法一和方法二半小时过去了,结果还出不来。我停掉了。
1 楼
dotjar
2011-03-21
在没有建立索引的情况下,查询表24167056条记录测试结果:
1-->
34行那个查询我的表花费:187.984s出来结果;
28行那个则超过5分钟都还没有结果;
继续测试中。。。
1-->
34行那个查询我的表花费:187.984s出来结果;
28行那个则超过5分钟都还没有结果;
继续测试中。。。
发表评论
-
navicat快捷键
2013-01-05 09:47 13891.ctrl+q 打开查询窗口2.ctrl ... -
mysql分表方案
2012-09-05 22:29 9105一、 概述分表是个目前算是比较炒的比较流行的概念,特别是在 ... -
mysql扩展至分库分表
2012-09-05 21:47 4046MySQL互联网Oracle企业应 ... -
批量修改SEQUENCE,序列同时增加10000
2012-06-26 16:40 1636select 'alter sequence ' || t1. ... -
oracle执行计划
2011-08-23 14:13 1178本文全面详细介绍oracle执行计划的相关的概念,访问数据 ... -
Oracle分页,Oracle中rownum与rowid的理解
2011-08-15 21:33 1880一、 oracle ... -
oracle--如何分析执行计划
2011-08-15 21:31 4257例1: 假设LARGE_TABLE ... -
Oracle优化----索引原理篇
2011-08-15 21:22 9982006-04-04 15:09 1561人阅读 评论(0) ... -
ORACLE执行计划
2011-06-22 17:27 15121 ,什么是执行计划 所谓执行计划,顾名思义,就是对一 ... -
MYSQL 字符
2011-04-23 00:05 1038因为不知道什么时候 ... -
ORACLE用户管理
2011-04-22 14:40 1397这里将介绍Oracle修改用户权限的实现过程,包括一些权限管 ... -
数据库表设计细节
2011-04-11 22:48 1965数据库建表原则 数据 ... -
数据库设计的14个技巧
2011-04-11 22:19 10041. 原始单据与实体之间的关系 可以是一对一、一对多、多对 ... -
ORACLE xmltype 遍历
2011-03-14 16:05 1994DECLARE var XMLType; ... -
ORACLE EXCEPTION总结
2011-03-14 14:53 1419文章分类:数据库 关键字: oracle 一 ORACLE ... -
Oracle存储过程解析XML,并把数据持久化
2011-03-14 14:52 1907需要解析的xml文件:people.xml 1 < ... -
oracle对大对象类型操作:blob,clob,nclob,bfile
2011-03-14 14:49 18503-4 Lob类型 ... -
impdp expdp使用小结
2011-03-11 17:29 2313\ 最近我们迁移数据库,其中涉及到了数据迁移 sql ... -
oracle表空间限额不足问题解决
2011-03-11 16:37 1300web程序访问数据库是,总是报 表空间“hnsd”限额不 ... -
ORACLE JOB
2011-03-11 15:56 1179、设置初始化参数 job_qu ...
相关推荐
按某一字段分组取最大(小)值所在行的数据
使用Linq语法与Lambda表达式分组取泛型数组某列的最小值/最大值
主要是介绍在 JDK8中使用 stream 流的 groupingBy 方法源进行最大值分组、最小值分组、平均值分组、统计分组
–按某一字段分组取最大(小)值所在行的数据 代码如下: /* 数据如下: nameval memo a 2 a2(a的第二个值) a 1 a1–a的第一个值 a 3 a3:a的第三个值 b 1 b1–b的第一个值 b 3 b3:b的第三个值 b 2 b2b2b2b2 b 4 b4b4 b ...
本示例探讨的是如何使用JavaScript实现JSON数组的分组合并操作,这对于数据处理和分析尤其有用。下面将详细解释这个示例中的关键知识点。 1. **遍历JSON数组**: 在示例中,我们首先通过`for`循环遍历输入的JSON...
本篇文章详细介绍了如何使用MySQL实现分组取n条最大记录的功能。通过精心设计的SQL查询语句,我们可以有效地解决这类问题。这种方法不仅适用于上述具体场景,还可以扩展应用于其他类似的需求,例如按不同标准分组并...
在MySQL中,获取分组后每组的最大值是一项常见的数据分析任务,这通常涉及到聚合函数和分组查询。本文将详细讲解如何使用SQL语句来实现这个功能,通过一个具体的实例来帮助理解。 首先,我们创建了一个名为`test`的...
pandas获取groupby分组里最大值所在的行方法 如下面这个DataFrame,按照Mt分组,取出Count最大的那行 import pandas as pd df = pd.DataFrame({'Sp':['a','b','c','d','e','f'], 'Mt':['s1', 's1', 's2','s2','s2','...
表:t_test -------------------------------------- id(int) cost(int) des Autoid(id) -------------------------------------- 1 10 aaaa 1 1 15 bbbb 2 1 20 cccc 3 ...取每一类id中cost最大的纪录
要按`name`分组取最大`val`值所在行的数据,有以下五种常见方法: 1. **子查询关联法**: ```sql select a.* from tb a where val = (select max(val) from tb where name = a.name) order by a.name; ``` 这种...
该脚本包含递归查询、删除数据表中重复数据、分组取最大记录,行列互转、多行合并等不常见但是非常实用的oracle函数并附带详细的实例持续更新中
##### 取分组中前N行(排名前几名) 假设我们需要取出每个`UserID`下`OrderID`排名前两名的数据,可以这样实现: ```sql SELECT ID, UserID, OrderID FROM ( SELECT *, ROW_NUMBER() OVER (PARTITION BY UserID ...
3. 根据最小值和最大值确定整个数据集的范围,然后根据分组数目计算组距。 4. 对数据集进行迭代,根据确定的组距将数据分配到对应的分组中。 在实际编程实现过程中,可能需要使用Java的基础类库如Math类来计算均值...
这可以帮助决策者快速了解各个分类中的关键数据,比如销售额最高的产品、利润最大的部门等。Style Report是一款强大的报表软件,它提供了高效且准确的工具来满足这种需求。以下是使用Style Report制作排名前N名分组...
4. 使用`GROUP BY [col1]`按`Col1`字段进行分组,对每个分组取`MAX([col2])`作为最大值。 示例代码如下: ```sql DECLARE @T TABLE ([Col1] INT, [Col2] INT, [Col3] INT, [Col4] INT, [Col5] INT, [Col6] INT, ...
根据提供的标题、描述和标签,我们可以深入探讨与“深入理解Linux”相关的重要知识点。由于给定的部分内容并未提供实质性的信息,以下将集中讨论Linux的基础概念、核心特性以及一些高级主题。 ...
Java8 Stream 自定义分组求和并排序的实现 Java8 Stream 自定义分组求和并排序的实现是 Java8 中一个非常重要的知识点,该知识点的实现可以帮助开发者快速地实现分组求和并排序的操作,从而提高开发效率和代码质量...