CREATE TABLE table1( [ID] [bigint] IDENTITY(1,1) NOT NULL, [Name] [nvarchar](128) NOT NULL, [class] int not null, [date] datetime not null)class 表示分类编号。 分类数不固定, 至少有上千种分类
date 表示该条记录被更新的时间
我们现在想获得每个分类最新被更新的5条记录。
解决方案
select id,name,class,date from(select id,name,class,date ,row_number() over(partition by class order by date desc)as rowindex from table1) awhere rowindex <= 5
create table #temp
(
company varchar(50),
product varchar(50),
inputDate datetime
)
insert into #temp(company,product,inputDate) values(‘杭州大明有限公司’,’汽车1′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘杭州大明有限公司’,’汽车2′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘杭州大明有限公司’,’汽车3′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘杭州大明有限公司’,’汽车4′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘杭州大明有限公司’,’汽车5′,’2010-7-1′)
insert into #temp(company,product,inputDate) values(‘北京小科有限公司’,’汽车1′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘北京小科有限公司’,’汽车2′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘北京小科有限公司’,’汽车3′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘北京小科有限公司’,’汽车4′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘上海有得有限公司’,’汽车1′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘上海有得有限公司’,’汽车2′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘上海有得有限公司’,’汽车3′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘上海有得有限公司’,’汽车4′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘天津旺旺有限公司’,’汽车4′,’2010-8-1′)
insert into #temp(company,product,inputDate) values(‘天津旺旺有限公司’,’汽车5′,’2010-8-1′)
select * from #temp
create proc getdata
@num int
as
begin
select top 4 * from
(
select ( select count(*) from #temp where company=a.company and product<=a.product) as 序号,a.company,a.product,a.inputDate
from #temp a
) b
where 序号>=@num
order by 序号,inputDate desc
end
go
getdata 2
/*
结果
1 杭州大明有限公司 汽车1 2010-08-01 00:00:00.000
1 北京小科有限公司 汽车1 2010-08-01 00:00:00.000
1 上海有得有限公司 汽车1 2010-08-01 00:00:00.000
1 天津旺旺有限公司 汽车4 2010-08-01 00:00:00.000
2 天津旺旺有限公司 汽车5 2010-08-01 00:00:00.000
2 上海有得有限公司 汽车2 2010-08-01 00:00:00.000
2 北京小科有限公司 汽车2 2010-08-01 00:00:00.000
2 杭州大明有限公司 汽车2 2010-08-01 00:00:00.000
3 杭州大明有限公司 汽车3 2010-08-01 00:00:00.000
3 北京小科有限公司 汽车3 2010-08-01 00:00:00.000
3 上海有得有限公司 汽车3 2010-08-01 00:00:00.000
4 北京小科有限公司 汽车4 2010-08-01 00:00:00.000
4 北京小科有限公司 汽车4 2010-08-01 00:00:00.000
4 上海有得有限公司 汽车4 2010-08-01 00:00:00.000
4 杭州大明有限公司 汽车4 2010-08-01 00:00:00.000
5 杭州大明有限公司 汽车5 2010-07-01 00:00:00.000
*/
–sql2005
create proc getdata2005
@num int
as
begin
select top 4 * from
(
select row_number() over (partition by company order by product ) as 序号,a.company,a.product,a.inputDate
from #temp a
) b
where 序号>=@num
order by 序号,inputDate desc
end
getdata2005 4
select * from #temp
select ( select count(*) from #temp where company+ product<=a.company+a.product) as 序号,a.company,a.product,a.inputDate
,a.company+a.product as 唯一标志一行
from #temp a
order by company,product
复制代码 代码如下:
Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/–>if object_id(N’company’) is not null
drop table company
go
create table company
(
companyname varchar(2),
product varchar(60)
)
–公司1
insert into company
select ‘A’,’A1′ union
select ‘A’,’A2′ union
select ‘A’,’A3′ union
select ‘A’,’A4′ union
select ‘A’,’A5′ union
select ‘A’,’A6′ union
select ‘A’,’A7′ union
select ‘A’,’A8′ union
select ‘A’,’A9′ union
select ‘A’,’A10′
–公司2
insert into company
select ‘B’,’B1′ union
select ‘B’,’B2′ union
select ‘B’,’B3′ union
select ‘B’,’B4′ union
select ‘B’,’B5′ union
select ‘B’,’B6′ union
select ‘B’,’B7′ union
select ‘B’,’B8′ union
select ‘B’,’B9′ union
select ‘B’,’B10′
–公司3
insert into company
select ‘C’,’C1′ union
select ‘C’,’C2′ union
select ‘C’,’C3′ union
select ‘C’,’C4′ union
select ‘C’,’C5′ union
select ‘C’,’C6′ union
select ‘C’,’C7′ union
select ‘C’,’C8′ union
select ‘C’,’C9′ union
select ‘C’,’C10′
–公司4
insert into company
select ‘D’,’D1′ union
select ‘D’,’D2′ union
select ‘D’,’D3′ union
select ‘D’,’D4′ union
select ‘D’,’D5′ union
select ‘D’,’D6′ union
select ‘D’,’D7′ union
select ‘D’,’D8′ union
select ‘D’,’D9′ union
select ‘D’,’D10′
–公司5
insert into company
select ‘E’,’E1′ union
select ‘E’,’E2′ union
select ‘E’,’E3′ union
select ‘E’,’E4′ union
select ‘E’,’E5′ union
select ‘E’,’E6′ union
select ‘E’,’E7′ union
select ‘E’,’E8′ union
select ‘E’,’E9′ union
select ‘E’,’E10′
–公司6
insert into company
select ‘F’,’F1′ union
select ‘F’,’F2′ union
select ‘F’,’F3′ union
select ‘F’,’F4′ union
select ‘F’,’F5′ union
select ‘F’,’F6′ union
select ‘F’,’F7′ union
select ‘F’,’F8′ union
select ‘F’,’F9′ union
select ‘F’,’F10′
–公司7
insert into company
select ‘G’,’G1′ union
select ‘G’,’G2′ union
select ‘G’,’G3′ union
select ‘G’,’G4′ union
select ‘G’,’G5′ union
select ‘G’,’G6′ union
select ‘G’,’G7′ union
select ‘G’,’G8′ union
select ‘G’,’G9′ union
select ‘G’,’G10′
–公司8
insert into company
select ‘H’,’H1′ union
select ‘H’,’H2′ union
select ‘H’,’H3′ union
select ‘H’,’H4′ union
select ‘H’,’H5′ union
select ‘H’,’H6′ union
select ‘H’,’H7′ union
select ‘H’,’H8′ union
select ‘H’,’H9′ union
select ‘H’,’H10′
–公司9
insert into company
select ‘I’,’I1′ union
select ‘I’,’I2′ union
select ‘I’,’I3′ union
select ‘I’,’I4′ union
select ‘I’,’I5′ union
select ‘I’,’I6′ union
select ‘I’,’I7′ union
select ‘I’,’I8′ union
select ‘I’,’I9′ union
select ‘I’,’I10′
–公司10
insert into company
select ‘J’,’J1′ union
select ‘J’,’J2′ union
select ‘J’,’J3′ union
select ‘J’,’J4′ union
select ‘J’,’J5′ union
select ‘J’,’J6′ union
select ‘J’,’J7′ union
select ‘J’,’J8′ union
select ‘J’,’J9′ union
select ‘J’,’J10′
IF (select Object_id(‘Tempdb..#t’)) IS NULL
select identity(int,1,1) as id,* into #t from company
order by left(product,1),cast(substring(product,2,2) as int)
if object_id(N’getdata’,’P’) is not null
drop table getdata
go
create proc getdata
@num1 int –第几页
as
begin
select companyname,product from
(
select row_number() over (partition by companyname order by id) as 序号,*
from #t
) a
where 序号=@num1
order by companyname
end
go
getdata 4
go
DROP procedure getdata
免责声明:
1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。
不得使用于非法商业用途,不得违反国家法律。否则后果自负!
2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。
NICE源码网 MsSql 每个分类取最新的几条的SQL实现代码 https://www.niceym.com/60778.html
猜你喜欢
- sqlserver存储过程语法详解 2022-05-24
- SQL Server 2005降级到2000的正确操作步骤分享 2022-05-24
- SQL Server 2005 数据库转 SQL Server 2000的方法小结 2022-05-24
- Sql中将datetime转换成字符串的方法(CONVERT) 2022-05-24
- mssql和sqlite中关于if not exists 的写法 2022-05-24
- 在SQL Server中查询资料库的TABLE数量与名称的sql语句 2022-05-24
- 通过系统数据库获取用户所有数据库中的视图、表、存储过程 2022-05-24
- 使用phpMyAdmin修改MySQL数据库root用户密码的方法 2022-05-24
- 一段脚本实现自动备份并保存最近几天的SQL数据库 2022-05-24
- sql查询表中根据某列排序的任意行语句 2022-05-24