sql面试题(转载)

一组通话记录(总共500万条):
ID 主叫号码 被叫号码通话起始时间   通话结束时间           通话时长
1  98290000 0215466546656 2007-02-01 09:49:53.000 2007-02-01 09:50:16.000 23
2  98290000 021546654666  2007-02-01 09:50:29.000 2007-02-01 09:50:41.000 12
3  98290000 021546654666  2007-02-01 09:50:58.000 2007-02-01 09:51:12.000 14
4  68290900 0755133329866 2007-02-01 10:04:31.000 2007-02-01 10:07:13.000 162
5  78290000 0755255708638 2007-02-01 10:48:26.000 2007-02-01 10:49:23.000 57
6  78290000 0755821119109 2007-02-01 10:49:39.000 2007-02-01 10:52:55.000 196
7  78290000 035730928370  2007-02-01 11:30:45.000 2007-02-01 11:31:58.000 73
8  78290000 0871138889904 2007-02-01 11:33:47.000 2007-02-01 11:35:00.000 73
9  68290000 035730928379  2007-02-01 11:52:20.000 2007-02-01 11:54:56.000 156
10 68290000 0298521811199 2007-02-01 12:44:45.000 2007-02-01 12:45:04.000 19

求其中同一个号码的两次通话之间间隔大于10秒的通话记录ID
例如:6,7,8,9,10条记录均符合。

——————————————————————————————————————————

if object_id('pubs..tb') is not null
   drop table tb
go

create table tb(ID int,主叫号码 varchar(20),被叫号码 varchar(20),通话起始时间 datetime,通话结束时间 datetime,通话时长 int)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(1  ,'98290000', '0215466546656', '2007-02-01 09:49:53.000', '2007-02-01 09:50:16.000', 23)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(2  ,'98290000', '021546654666' , '2007-02-01 09:50:29.000', '2007-02-01 09:50:41.000', 12)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(3  ,'98290000', '021546654666' , '2007-02-01 09:50:58.000', '2007-02-01 09:51:12.000', 14)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(4  ,'68290900', '0755133329866', '2007-02-01 10:04:31.000', '2007-02-01 10:07:13.000', 162)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(5  ,'78290000', '0755255708638', '2007-02-01 10:48:26.000', '2007-02-01 10:49:23.000', 57)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(6  ,'78290000', '0755821119109', '2007-02-01 10:49:39.000', '2007-02-01 10:52:55.000', 196)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(7  ,'78290000', '035730928370' , '2007-02-01 11:30:45.000', '2007-02-01 11:31:58.000', 73)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(8  ,'78290000', '0871138889904', '2007-02-01 11:33:47.000', '2007-02-01 11:35:00.000', 73)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(9  ,'68290000', '035730928379' , '2007-02-01 11:52:20.000', '2007-02-01 11:54:56.000', 156)
insert into tb(ID,主叫号码,被叫号码,通话起始时间,通话结束时间,通话时长) values(10 ,'68290000', '0298521811199', '2007-02-01 12:44:45.000', '2007-02-01 12:45:04.000', 19)
go

select * from
(
select a.* from tb a,
(select * from tb )  b
where a.id = b.id - 1 and a.主叫号码 = b.主叫号码 and datediff(minute , a.通话结束时间 , b.通话起始时间) >= 10
union all
select b.* from tb b,
(select * from tb )  a
where a.id = b.id - 1 and a.主叫号码 = b.主叫号码 and datediff(minute , a.通话结束时间 , b.通话起始时间) >= 10
) t
order by id

drop table tb

/*
ID          主叫号码                 被叫号码                 通话起始时间                                                 通话结束时间                                                 通话时长       
----------- -------------------- -------------------- ------------------------------------------------------ ------------------------------------------------------ -----------
6           78290000             0755821119109        2007-02-01 10:49:39.000                                2007-02-01 10:52:55.000                                196
7           78290000             035730928370         2007-02-01 11:30:45.000                                2007-02-01 11:31:58.000                                73
9           68290000             035730928379         2007-02-01 11:52:20.000                                2007-02-01 11:54:56.000                                156
10          68290000             0298521811199        2007-02-01 12:44:45.000                                2007-02-01 12:45:04.000                                19

(所影响的行数为 4 行)
*/

——————————————————————————————————————————————————

select a.id,b.id from
表 a,表 b where b.id>a.id and b.id=(select min(id) from tb where id>a.id
and (a.主叫号码=b.主叫号码 or a.主叫号码=b.被叫号码 or a.被叫号码=b.主叫号码 or a.被叫号码=b.被叫号码))
and DATEDIFF(s,a.通话结束时间,b.通话起始时间)>10

——————————————————————————————————————————————————

select *
from table1 as a
where exist(
             select b.* from
                table1 as b
               inner join a on a.主叫号码=b.主叫号码
                          and a.id>b.id
                          and datedif(second,a.起始时间,b.结束时间)>10)

——————————————————————————————————————————————————

呵呵,这题刚用group by语句,没有各位想得那么复杂。
SELECT *
FORM 通话记录表
WHERE datediff(second , 通话记录表.通话结束时间 , 通话记录表.通话起始时间) > 10
GROUP BY 主叫号码
HAVING count(*)>=2

——————————————————————————————————————————————————

DATEDIFF(mi,a.通话结束时间,b.通话起始时间)>10//十分
DATEDIFF(s,a.通话结束时间,b.通话起始时间)>10//十秒
 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值