首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > SQL Server >

sql怎么查询出指定字段不重复但是要保留最新的一个字段的值

2013-11-21 
sql如何查询出指定字段不重复但是要保留最新的一个字段的值sql如何查询出所有符合“指定字段不重复但是要保

sql如何查询出指定字段不重复但是要保留最新的一个字段的值
sql如何查询出所有符合“指定字段不重复但是要保留最新的一个字段”他们所有的值的最新记录。 sql
[解决办法]

引用:
sql如何查询出所有符合“指定字段不重复但是要保留最新的一个字段”他们所有的值的最新记录。


是类似这样吗,用row_number()函数就可以的,你试试:

drop table tb
go

create table tb(v int,vv varchar(10),t datetime)

insert into tb
select 1,'ee','2012-09-09' union all
select 1,'ff','2012-09-11' union all
select 1,'aa','2012-10-09' union all
select 2,'aa','2012-09-09' union all
select 2,'bb','2012-11-18' union all
select 2,'cc','2012-01-21' union all
select 2,'dd','2012-12-09'


select v,vv,t
from 
(
select *,
       ROW_NUMBER() over(partition by v order by t desc) as rownum
from tb
)t
where rownum = 1
/*
vvvt
1aa2012-10-09 00:00:00.000
2dd2012-12-09 00:00:00.000
*/

[解决办法]
select 重复字段列,max(不重复的字段)
from tb
where 复合条件的数据

更准确的写法需要你提供更多的信息
[解决办法]
引用:
select 重复字段列,max(不重复的字段)
from tb
where 复合条件的数据

更准确的写法需要你提供更多的信息

同意这种说法!
[解决办法]

select * from tb a 
left join (select max(id) as id from tb group by 重复字段...)b
on a.id=b.id

热点排行