用户消费总金额 2000以下 2000-4000 4000-6000 查询连续数字,统计个数

简介:

createtable tb_1(
    id 
int,
    xiaofei 
money,
    userid 
int,
    addtime 
datetime
)
insertinto tb_1 values(18801getdate())
insertinto tb_1 values(29502getdate())
insertinto tb_1 values(37401getdate())
insertinto tb_1 values(42544getdate())
insertinto tb_1 values(525415getdate())
insertinto tb_1 values(6803getdate())
insertinto tb_1 values(738701getdate())
insertinto tb_1 values(81002getdate())
insertinto tb_1 values(91803getdate())
insertinto tb_1 values(1032406getdate())

select*from tb_1

select userid, sum(xiaofei) as'消费总金额'from tb_1 groupby userid orderbysum(xiaofei) desc

select userid,sum(xiaofei) as'2000以下'from tb_1 groupby userid havingsum(xiaofei) <2000 
select userid,sum(xiaofei) as'2000-4000'from tb_1 groupby userid havingsum(xiaofei) between2000and4000 
select userid,sum(xiaofei) as'4000-6000'from tb_1 groupby userid havingsum(xiaofei) between4000and6000 

droptable tb_1

/*

userid      消费总金额
----------- ---------------------
1           5490.00
6           3240.00
5           2541.00
2           1050.00
3           260.00
4           254.00

(6 行受影响)

userid      2000以下
----------- ---------------------
2           1050.00
3           260.00
4           254.00

(3 行受影响)

userid      2000-4000
----------- ---------------------
5           2541.00
6           3240.00

(2 行受影响)

userid      4000-6000
----------- ---------------------
1           5490.00

(1 行受影响)

*/

 

 --查询连续数字,统计个数

create  table tb1(NUM  INT)
INSERT  INTO tb1
SELECT  1  
UNION  ALL  SELECT  2  
UNION  ALL  SELECT  3  
UNION  ALL  SELECT  4  
UNION  ALL  SELECT  5  
UNION  ALL  SELECT  12  
UNION  ALL  SELECT  17  
UNION  ALL  SELECT  18  
UNION  ALL  SELECT  19  
UNION  ALL  SELECT  20  
UNION  ALL  SELECT  25  
UNION  ALL  SELECT  30  
go

select  *  from tb1
drop  table tb1,#tb

-- sql2000
select num,rid = identity( int, 1, 1into #tb  from tb1
select  min(num) minNum, max(num) maxNum, count( 1) cnt
from #tb
group  by (num -rid)
having  count( *>  1

-- sql2005

select 开始 = min(num),结束 = max(num), count( 1) cnt  from     (
select row_number() over ( order  by num)  as rid, *  from tb1
) a  group  by num -rid  having( count( 1) > 1)


-- 结果:
--
1        5    5
--
12    12    1
--
17    20    4
--
25    25    1

--30    30    1 


    本文转自曾祥展博客园博客,原文链接:http://www.cnblogs.com/zengxiangzhan/archive/2010/01/03/1638193.html,如需转载请自行联系原作者



相关文章
|
网络架构
|
Ubuntu Linux iOS开发
ROS与操作系统版本对应关系
ROS与操作系统版本对应关系
4775 0
|
5天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
309 116
|
20天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
7天前
|
数据采集 人工智能 自然语言处理
Meta SAM3开源:让图像分割,听懂你的话
Meta发布并开源SAM 3,首个支持文本或视觉提示的统一图像视频分割模型,可精准分割“红色条纹伞”等开放词汇概念,覆盖400万独特概念,性能达人类水平75%–80%,推动视觉分割新突破。
519 47
Meta SAM3开源:让图像分割,听懂你的话
|
14天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
697 222
|
2天前
|
Windows
dll错误修复 ,可指定下载dll,regsvr32等
dll错误修复 ,可指定下载dll,regsvr32等
137 95