sql server 增加分组序号

SQL2000自制row_number

SELECT (SELECT COUNT(*) FROM main1 p1 WHERE p1.编号 <= p2.编号) AS rowNumber, *
  FROM main1 p2  ORDER BY 编号

很简单,但是数据量大的时候会十分的消耗性能

sql server2005以后

ROW_NUMBER() OVER()函数用法详解 (分组排序 例子多)
原创置顶 一彡十 最后发布于2018-09-18 19:11:38 阅读数 92385 收藏
展开

和彡十一起学java
学习分享专栏
一彡十
¥9.90
去订阅
语法格式:row_number() over(partition by 分组列 order by 排序列 desc)

row_number() over()分组排序功能:

在使用 row_number() over()函数时候,over()里头的分组以及排序的执行晚于 where 、group by、  order by 的执行。

例一:

表数据:

create table TEST_ROW_NUMBER_OVER(
id varchar(10) not null,
name varchar(10) null,
age varchar(10) null,
salary int null
);
select * from TEST_ROW_NUMBER_OVER t;

insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(1,‘a‘,10,8000);
insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(1,‘a2‘,11,6500);
insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(2,‘b‘,12,13000);
insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(2,‘b2‘,13,4500);
insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(3,‘c‘,14,3000);
insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(3,‘c2‘,15,20000);
insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(4,‘d‘,16,30000);
insert into TEST_ROW_NUMBER_OVER(id,name,age,salary) values(5,‘d2‘,17,1800);
一次排序:对查询结果进行排序(无分组)

select id,name,age,salary,row_number()over(order by salary desc) rn
from TEST_ROW_NUMBER_OVER t
结果:

进一步排序:根据id分组排序

select id,name,age,salary,row_number()over(partition by id order by salary desc) rank
from TEST_ROW_NUMBER_OVER t
结果:

再一次排序:找出每一组中序号为一的数据

select * from(select id,name,age,salary,row_number()over(partition by id order by salary desc) rank
from TEST_ROW_NUMBER_OVER t)
where rank <2
结果:

排序找出年龄在13岁到16岁数据,按salary排序

select id,name,age,salary,row_number()over(order by salary desc) rank
from TEST_ROW_NUMBER_OVER t where age between ‘13‘ and ‘16‘
结果:结果中 rank 的序号,其实就表明了 over(order by salary desc) 是在where age between and 后执行的

例二:

1.使用row_number()函数进行编号,如

select email,customerID, ROW_NUMBER() over(order by psd) as rows from QT_Customer
原理:先按psd进行排序,排序完后,给每条数据进行编号。

2.在订单中按价格的升序进行排序,并给每条记录进行排序代码如下:

select DID,customerID,totalPrice,ROW_NUMBER() over(order by totalPrice) as rows from OP_Order
3.统计出每一个各户的所有订单并按每一个客户下的订单的金额 升序排序,同时给每一个客户的订单进行编号。这样就知道每个客户下几单了:

select ROW_NUMBER() over(partition by customerID order by totalPrice)
as rows,customerID,totalPrice, DID from OP_Order
4.统计每一个客户最近下的订单是第几次下的订单:

with tabs as
(
select ROW_NUMBER() over(partition by customerID order by totalPrice)
as rows,customerID,totalPrice, DID from OP_Order
)
select MAX(rows) as ‘下单次数‘,customerID from tabs
group by customerID
5.统计每一个客户所有的订单中购买的金额最小,而且并统计改订单中,客户是第几次购买的:

思路:利用临时表来执行这一操作。

1.先按客户进行分组,然后按客户的下单的时间进行排序,并进行编号。

2.然后利用子查询查找出每一个客户购买时的最小价格。

3.根据查找出每一个客户的最小价格来查找相应的记录。

with tabs as
(
select ROW_NUMBER() over(partition by customerID order by insDT)
as rows,customerID,totalPrice, DID from OP_Order
)
select * from tabs
where totalPrice in
(
select MIN(totalPrice)from tabs group by customerID
)
6.筛选出客户第一次下的订单。

思路。利用rows=1来查询客户第一次下的订单记录。

with tabs as
(
select ROW_NUMBER() over(partition by customerID order by insDT) as rows,* from OP_Order
)
select * from tabs where rows = 1
select * from OP_Order
7.注意:在使用over等开窗函数时,over里头的分组及排序的执行晚于“where,group by,order by”的执行。

select
ROW_NUMBER() over(partition by customerID order by insDT) as rows,
customerID,totalPrice, DID
from OP_Order where insDT>‘2011-07-22‘
 
————————————————
版权声明:本文为CSDN博主「一彡十」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_25221835/article/details/82762416

原文地址:https://www.cnblogs.com/yclizq/p/12185365.html

时间: 2024-11-06 18:50:22

sql server 增加分组序号的相关文章

SQL SERVER 实现分组合并实现列数据拼接

需求场景: SQL SERVER 中组织的数据结构是一个层级关系,现在需要抓出每个组织节点以上的全部组织信息,数据示例如下: ADOrg_ID--------------ParentID-----------------ShortName 001                                                                 顶级组织名称 001.021                     001                        

为sql server 增加 parseJSON 和 ToJSON 函数

在SqlServer中增加Json处理的方法 Sql Server 存储非结构话数据可以使用xml类型,使用xpath方式查询,以前写过一篇随笔:Sql Server xml 类型字段的增删改查 除了xml类型也可以使用文本类型(char.vchar等)存储json格式的数据,如何在sql语句中解析json数据,这里有一篇博客 [转]在SqlServer 中解析JSON数据,它的来源是Consuming JSON Strings in SQL Server 针对json解析需要一个自定义类型Hi

为SQL Server 增加链接到SQL Server 的链接服务器

整体的分析一下好有一个思路.我们的目的是完成一个到远程服务器的链接. 第一:我们要知道这台服务器在哪(也就是要知道它的IP地址,如果是在同一个网络中知道它的计算机名也是可以的.因为一台服务器上可以安装多个SQL Server 实例,如果我们要连接到非默认实例时我们要指定实例名) 第二:我们要以那个用户名登录到目标SQL Server 服务器上去. 第三:我们本地是以哪个用户登录的. ---------------------------------------------------------

sql server如何分组编号

我们在生产实践中经常会有这样的需求:分组编号. 如下有一个城市区域表region: 我们需要对上表region按city分组,对region进行排序,得到如下结果: 具体sql如下: 1 select city,region, 2 right('100'+row_number()over(partition by city order by region),2) as region_no 3 from region 此方法主要是运用over函数通过对city进行分组后,再对region进行排序(

利用SQL语句产生分组序号

partition  by关键字是分析性函数的一部分,它和聚合函数不同的地方在于它能返回一个分组中的多条记录,而聚合函数一般只有一条反映统计值的记录,partition  by用于给结果集分组,如果没有指定那么它把整个结果集作为一个分组 那么我们怎么进行分组排序呢,见SQL语句如下:

Sql Server 增加字段、修改字段、修改类型、修改默认值

1.修改字段名: alter table 表名 rename column A to B 2.修改字段类型: alter table 表名 alter column 字段名 type not null 3.修改字段默认值 alter table 表名 add default (0) for 字段名 with values 如果字段有默认值,则需要先删除字段的约束,在添加新的默认值, select c.name from sysconstraints a inner join syscolumns

sql server求分组最大值,最小值,最大值对应时间,和最小值对应时间

先创建数据库 CREATE TABLE [dbo].[Students]( [Id] [int] IDENTITY(1,1) NOT NULL, [age] [int] NULL, [name] [nvarchar](50) NULL, [addTime] [datetime]  NULL) ON [PRIMARY] 插入几条测试数据 INSERT [dbo].[Students] ([age], [name], [addTime]) VALUES (22, N'李四', '2015-04-08

sql server——分组查询(方法和思想)

思想 先排序在汇总 sql server里分组查询通常用于配合聚合函数,达到分类汇总统计的信息.而其分类汇总的本质实际上就是先将信息排序,排序后相同类别的信息会聚在一起,然后通过需求进行统计计算. 使用GROUP BY进行分组查询 实例演示 --查询男女生的人数 在没有学习分组查询之前,我们可以安装常规的思路解决查询需求: select count(*) from student where sex='男' select count(*) from student where sex='女' 那

SQL Server常语法语句操作

SQL Server语句操作 --1.获取表的主键字段SELECT name FROM SysColumns WHERE id=Object_Id('表名') and colid=(select top 1 colid from sysindexkeys where id=Object_Id('表名')) select A.COLUMN_NAME  from INFORMATION_SCHEMA.CONSTRAINT_COLUMN_USAGE A join(select * from sysob