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

一个去重复的有关问题!

2012-12-17 
一个去重复的问题!!!CREATE TABLE #F( InvieteID INT IDENTITY(1,1), FromUserId INT, ToUserId INT, AddT

一个去重复的问题!!!


CREATE TABLE #F
(
 InvieteID INT IDENTITY(1,1),
 FromUserId INT,
 ToUserId INT,
 AddTime DATETIME,
 States INT
)
INSERT INTO #F(FromUserId,ToUserId,AddTime,States)
SELECT 135732,153,'2012-11-02 18:01:48.783',0 UNION
SELECT 135732,184,'2012-11-02 18:00:30.040',0 UNION
SELECT 135732,152,'2012-11-02 17:30:38.513',0 UNION
SELECT 135728,135776,'2012-11-02 16:35:12.977',0 UNION
SELECT 16,7,'2012-11-02 11:25:21.620',0 UNION
SELECT 135732,7,'2012-11-02 11:23:59.220',0 UNION
SELECT 135728,135776,'2012-11-02 09:50:03.023',2 UNION
SELECT 135728,135776,'2012-11-02 09:49:33.303',0 UNION
SELECT 135728,135776,'2012-11-02 09:49:17.303',1 UNION
SELECT 135728,135776,'2012-11-02 09:48:42.507',0 UNION
SELECT 135728,135776,'2012-11-02 09:46:02.663',0 UNION
SELECT 135728,135776,'2012-11-02 09:44:39.617',2 UNION
SELECT 135732,121,'2012-10-31 10:26:09.563',0 UNION
SELECT 135732,127,'2012-10-29 10:02:09.617',0 UNION
SELECT 135732,112,'2012-10-29 10:02:00.750',0 UNION
SELECT 135732,109,'2012-10-29 10:01:58.287',0 UNION
SELECT 135732,102,'2012-10-29 10:01:34.147',0

DROP TABLE #F
/*
想要的结果,相同的FromUserId和ToUserId只取出时间最近的一条记录,即使States不同,也是取出时间最近的一条记录

*/


[最优解释]
select * from #F a
 where not exists(select 1 from #F 
     where FromUserId=a.FromUserId and ToUserId=a.ToUserId and AddTime>a.AddTime)
[其他解释]

select
*
from
#F a
where
a.AddTime=(
select 
MAX(b.AddTime)
from 
#F b
where
a.FromUserId=b.FromUserId 
and a.InvieteID=b.InvieteID
and a.States=b.States
)

[其他解释]
CREATE TABLE #F
(
 InvieteID INT IDENTITY(1,1),
 FromUserId INT,
 ToUserId INT,
 AddTime DATETIME,
 States INT
)
INSERT INTO #F(FromUserId,ToUserId,AddTime,States)
SELECT 135732,153,'2012-11-02 18:01:48.783',0 UNION
SELECT 135732,184,'2012-11-02 18:00:30.040',0 UNION
SELECT 135732,152,'2012-11-02 17:30:38.513',0 UNION
SELECT 135728,135776,'2012-11-02 16:35:12.977',0 UNION
SELECT 16,7,'2012-11-02 11:25:21.620',0 UNION
SELECT 135732,7,'2012-11-02 11:23:59.220',0 UNION
SELECT 135728,135776,'2012-11-02 09:50:03.023',2 UNION
SELECT 135728,135776,'2012-11-02 09:49:33.303',0 UNION
SELECT 135728,135776,'2012-11-02 09:49:17.303',1 UNION
SELECT 135728,135776,'2012-11-02 09:48:42.507',0 UNION
SELECT 135728,135776,'2012-11-02 09:46:02.663',0 UNION
SELECT 135728,135776,'2012-11-02 09:44:39.617',2 UNION
SELECT 135732,121,'2012-10-31 10:26:09.563',0 UNION
SELECT 135732,127,'2012-10-29 10:02:09.617',0 UNION
SELECT 135732,112,'2012-10-29 10:02:00.750',0 UNION
SELECT 135732,109,'2012-10-29 10:01:58.287',0 UNION


SELECT 135732,102,'2012-10-29 10:01:34.147',0
go

select
*
from
#F a
where
a.AddTime=(
select 
MAX(b.AddTime)
from 
#F b
where
a.FromUserId=b.FromUserId 
and a.ToUserId=b.ToUserId
and a.States=b.States
)
/*
InvieteID   FromUserId  ToUserId    AddTime                 States
----------- ----------- ----------- ----------------------- -----------
17          135732      184         2012-11-02 18:00:30.040 0
16          135732      153         2012-11-02 18:01:48.783 0
15          135732      152         2012-11-02 17:30:38.513 0
14          135732      127         2012-10-29 10:02:09.617 0
13          135732      121         2012-10-31 10:26:09.563 0
12          135732      112         2012-10-29 10:02:00.750 0
11          135732      109         2012-10-29 10:01:58.287 0
10          135732      102         2012-10-29 10:01:34.147 0
9           135732      7           2012-11-02 11:23:59.220 0
7           135728      135776      2012-11-02 09:50:03.023 2
5           135728      135776      2012-11-02 09:49:17.303 1
8           135728      135776      2012-11-02 16:35:12.977 0
1           16          7           2012-11-02 11:25:21.620 0

(13 行受影响)



*/


[其他解释]
select FromUserId,ToUserId,max(AddTime) as AddTime from 

(SELECT 135732 as FromUserId,153 as ToUserId,'2012-11-02 18:01:48.783' as AddTime,0 as States UNION
SELECT 135732,184,'2012-11-02 18:00:30.040',0 UNION
SELECT 135732,152,'2012-11-02 17:30:38.513',0 UNION
SELECT 135728,135776,'2012-11-02 16:35:12.977',0 UNION
SELECT 16,7,'2012-11-02 11:25:21.620',0 UNION


SELECT 135732,7,'2012-11-02 11:23:59.220',0 UNION
SELECT 135728,135776,'2012-11-02 09:50:03.023',2 UNION
SELECT 135728,135776,'2012-11-02 09:49:33.303',0 UNION
SELECT 135728,135776,'2012-11-02 09:49:17.303',1 UNION
SELECT 135728,135776,'2012-11-02 09:48:42.507',0 UNION
SELECT 135728,135776,'2012-11-02 09:46:02.663',0 UNION
SELECT 135728,135776,'2012-11-02 09:44:39.617',2 UNION
SELECT 135732,121,'2012-10-31 10:26:09.563',0 UNION
SELECT 135732,127,'2012-10-29 10:02:09.617',0 UNION
SELECT 135732,112,'2012-10-29 10:02:00.750',0 UNION
SELECT 135732,109,'2012-10-29 10:01:58.287',0 UNION
SELECT 135732,102,'2012-10-29 10:01:34.147',0) as a
group by FromUserId,ToUserId


[其他解释]
引用:
select * from #F a
 where not exists(select 1 from #F 
     where FromUserId=a.FromUserId and ToUserId=a.ToUserId and AddTime>a.AddTime)

这种必须用嵌套查询是么?
[其他解释]


晕了

热点排行