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

简介: 近期在上RFID技术课程,前期要求巩固SQL知识,课上做了下面几道练习题,由此记录一下先把以下程序复制到新查询窗口中运行:create database EX30918-- 创建表create table T_CallRecords(...

近期在上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

显示的结果如下:

img_e40fc6bbe7ac2dc74749dfeff3331d5e.png

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

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

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

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

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

-- 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
img_92cda62cd65ad1cfe9cd58d43a99edbc.png

-- 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
img_ef83c5a52cd6ff3421b34e01dc6c3727.png

-- 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%')) + '秒')
img_dd88c4706177ffa2d83db1b3de28b128.png
目录
相关文章
|
7月前
|
SQL Perl
PL/SQL经典练习
PL/SQL经典练习
|
7月前
|
SQL 分布式计算 数据挖掘
Hive SQL初级练习(30题)
Hive SQL初级练习(30题)
|
SQL 存储 Java
Mybatis实战练习四【单个条件(动态SQL)&添加数据】(下)
Mybatis实战练习四【单个条件(动态SQL)&添加数据】
|
SQL 存储 关系型数据库
【MYSQL高级】Mysql 表的七种连接方式【附带练习sql】
【MYSQL高级】Mysql 表的七种连接方式【附带练习sql】
218 0
|
6月前
|
SQL 存储 数据库
技术好文:SQL查询语句基本练习
技术好文:SQL查询语句基本练习
|
7月前
|
SQL 数据挖掘 HIVE
【Hive SQL 每日一题】在线课程学生行为数据分析
该数据分析师任务是分析在线学习平台的学生行为,以优化课程内容和学习体验。提供的数据包括`students`表(含学生ID、姓名、年龄和性别)和`course_activity`表(含活动ID、学生ID、课程ID、活动日期和学习时长)。分析涉及:1) 学生参加的课程数量,2) 课程总学习时长,3) 按性别分组的平均学习时长,4) 学生首次参加的课程及日期,5) 学生最近一次学习的时长,以及6) 参与学生最多的课程。所有查询都使用了SQL,部分涉及窗口函数和分组统计。数据集可在给定链接下载。
71 2
|
7月前
|
SQL 关系型数据库 MySQL
SQL基础开发与应用-课程及场景介绍
这是一门关于《SQL基础开发与应用》的课程介绍,主要针对数据库Clouder认证的第二阶段。课程以电商平台后端开发为背景,教授RDS for MySQL的SQL基础知识,包括存储过程、触发器和视图等高级特性,并指导学员使用Python进行数据库的增删改查操作。学习目标包括掌握SQL基础操作,了解RDS的高阶功能,并熟悉Python连接RDS进行数据处理。课程采用场景化教学,以跨境电商网站数据库搭建为例,帮助学员理解实际应用。
84 0
|
SQL Java 数据库连接
Mybatis实战练习四【单个条件(动态SQL)&添加数据】(上)
Mybatis实战练习四【单个条件(动态SQL)&添加数据】
|
7月前
|
SQL JSON 运维
dataworks常见问题之selectdb前置sql参数无法获取如何解决
DataWorks是阿里云提供的一站式大数据开发与管理平台,支持数据集成、数据开发、数据治理等功能;在本汇总中,我们梳理了DataWorks产品在使用过程中经常遇到的问题及解答,以助用户在数据处理和分析工作中提高效率,降低难度。
|
7月前
|
SQL
SQL语句多表查询练习
SQL语句多表查询练习
35 0