RFID课程前置——SQL巩固练习

近期在上RFID技术课程,前期要求巩固SQL知识,课上做了下面几道练习题,由此记录一下

先把以下程序复制到新查询窗口中运行:

create database EX30918

-- 创建表

create table T_CallRecords(

id int not null,

CallerNumber varchar(3),

TellNumber varchar(13),

StartDateTIme datetime,

EndDateTime datetime,

Primary key(Id)

);

--插入数据

insert into T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTIme)

values(1,'001','02088888888','2010-7-10 10:01','2010-7-10 10:05');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (2,'002','02088888888', '2010-7-11 13:41','2010-7-11 13:52');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (3,'003','89898989', '2010-7-11 14:42', '2010-7-11 14:49');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (4,'004','02188368981', '2010-7-13 21:04', '2010-7-13 21:18');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (5,'005','76767676', '2010-6-29 20:15', '2010-6-29 20:30');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (6,'006','02288878243', '2010-7-15 13:40', '2010-7-15 13:56');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (7,'007','67254686', '2010-7-13 11:06', '2010-7-13 11:19');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (8,'008','8623<st1:rtx w:st="on">1445</st1:rtx>', '2010-6-19 19:19', '2010-6-19 19:25');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (9,'009','87422368', '2010-6-19 19:25', '2010-6-19 19:36');

INSERT INTO T_CallRecords(Id,CallerNumber,TellNumber,StartDateTime,EndDateTime)

VALUES (10,'010','40045862245', '2010-6-19 19:50', '2010-6-19 19:59');

--修改呼叫员编号

UPDATE T_CallRecords SET CallerNumber='001' WHERE Id IN (1,2,3,6,9);

UPDATE T_CallRecords SET CallerNumber='002' WHERE Id IN (4,5);

UPDATE T_CallRecords SET CallerNumber='003' WHERE Id IN (7,8);

UPDATE T_CallRecords SET CallerNumber='004' WHERE Id=10;

--数据汇总

select * from T_CallRecords

显示的结果如下:

根椐上面的表完成以下题目:

-- 1) 输出所有数据中通话时间最长的5条记录。

select top 5 *, DATEDIFF(second,StartDateTime,EndDateTime) as 'SpanTimex' from T_CallRecords
order by 'SpanTimex' Desc

-- 2) 输出所有数据中拨打长途号码(对方号码以0开头)的总时长。

--输出所有数据中拨打长途号码
select *,DATEDIFF(second,StartDateTIme,EndDateTime) as 'Total_SpanTimex'  from T_CallRecords where TellNumber like '0%'
-- 输出所有数据中拨打长途号码(对方号码以0开头)的总时长
select sum(DATEDIFF(second,StartDateTIme,EndDateTime)) as 'Total_SpanTimex'  from T_CallRecords where TellNumber like '0%'

-- 3) 输出在2010年7月通话总时长最多的前三个呼叫员的编号。

--主要思路:
--算出2010-7到现在时间的月数month,数据中起始时间到现在时间等于month的,即2010年7月的记录
--sum(DATEDIFF(second,StartDateTIme,EndDateTime))算出通话总时长

select top 3 CallerNumber,sum(DATEDIFF(second,StartDateTIme,EndDateTime)) as 'Total_SpanTimex' from T_CallRecords
where DATEDIFF(month,StartDateTIme,getdate())=(select DATEDIFF(month,'2010-7-1',getdate()))
group by CallerNumber
order by 'Total_SpanTimex' desc

-- 4) 输出2010年7月拨打电话次数最多的前三个呼叫员的编号。

select top 3 CallerNumber, count(*) from T_CallRecords
where DATEDIFF(month,StartDateTIme,getdate())=(select DATEDIFF(month,'2010-7-1',getdate()))
group by CallerNumber

-- 5) 输出所有数据的拨号流水,并且在最后一行添加总呼叫时长。 -- 记录呼叫员编号、对方号码、通话时长 --... -- 汇总[市内号码总时长][长途号码总时长]

-- 5) 输出所有数据的拨号流水,并且在最后一行添加总呼叫时长。 

-- 记录呼叫员编号、对方号码、通话时长 
-- ...... 
-- 汇总[市内号码总时长][长途号码总时长] 

--取对应的列,转化类型;
--因为两个表加在一起,列的属性要一样!!!
select convert(nvarchar(50),CallerNumber) as N'呼叫员编码' , convert(nvarchar(50),TellNumber) as N'对方号码',
convert(nvarchar(50),DATEDIFF(second,StartDateTIme,EndDateTime)) as N'通话时长' from T_CallRecords

union all

select '汇总',
-- (select sum(DATEDIFF(second,StartDateTIme,EndDateTime)) from T_CallRecords  where TellNumber not like '0%')  算出市内号码总时长
--convert(nvarchar(50), (select sum(...) from T_CallRecords  where TellNumber not like '0%')) 转换类型方便转型
--select 
(select '市内号码总时长:' + convert(nvarchar(50), (select sum(DATEDIFF(second,StartDateTIme,EndDateTime)) from T_CallRecords  
where TellNumber not like '0%')) + '秒'),    --注意逗号!!!,两个逗号连接三个列为一行
(select '长途号码总时长:' + convert(nvarchar(50), (select sum(DATEDIFF(second,StartDateTIme,EndDateTime)) from T_CallRecords  
where TellNumber  like '0%')) + '秒')

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏跟着阿笨一起玩NET

无法将类型“System.Collections.Generic.IEnumerable<EmailSystem.Model.TemplateInfo>”隐式转换为“System.Collection

38210
来自专栏跟着阿笨一起玩NET

如何vs升级后10和12都能同时兼容

升级办法:先复制vs2008版本的解决方案文件。升级2012后,再将文件复制到目录里面即可。注意升级过程中产生的升级文件(UpgradeLog文件)不能删除!

7110
来自专栏happyJared

1万步21天钉钉运动大神赛

  目前所在的企业,从入职开始到现在,内部沟通协作的主要软件也就是钉钉。三月初的时候,偶然在钉钉运动一栏中发现了这个活动,当时也没怎么犹豫,果断支付了2元契约金...

25810
来自专栏黄Java的地盘

《麦肯锡 问题分析与解决技巧》——阅读笔记(共16章)

《麦肯锡 问题分析与解决技巧》是一本关于问题分析与如何解决问题的书籍,在阅读过程中收获不少,因此留下读书笔记方便其他人来进行学习。

79110
来自专栏孟永辉

恒大入主法拉第,FF91真的要来了吗?

自恒大入主法拉第之后,FF91落地的步伐似乎开始逐步加快。在许家印到法拉第公司考察之后,FF91在落地到中国的步伐更加快速。就在上周,恒大法拉第未来智能汽车集团...

7820
来自专栏跟着阿笨一起玩NET

NULL不能和任何字段比较和运算

14410
来自专栏孟永辉

锤子手机推“无限屏”新机:让我们为老罗的创新点赞

人们对于锤子手机的发布会的期待其实更多的是在看罗永浩的“单口相声”。无论锤子手机如何,观众依然能够在锤子手机发布会上过一回嘴瘾。罗永浩对于自己,对于友商,对于行...

13050
来自专栏加州阳光87°F

此处芯安是吾乡 ——Seal ring

版图生涯是一条工程师修炼技术与心境凝练的修行路。俗话说“工欲善其事必先利其器”,练就一套得心应手的手上功夫是必须要刷满的技能点,如同老木匠视如珍宝的工具箱。出征...

49230
来自专栏pangguoming

申请高级项目经理

要评计算机系统集成项目经理必须先考软考的系统集成项管理工程师,如果想评计算机系统集成高级项目经理必须考软考的信息系统项目管理师。考试一年2次,每年的5月下旬和1...

67120
来自专栏雪地二货笔记库

vue学习笔记9-监听属性-watch

这样就可以实现绑定 而且他后面也有很多功能,比如.lazy,惰性更新,只有焦点离开才会更新

9210

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励