IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 大数据 -> 【数据库系统概论】实验二 SQL数据查询 -> 正文阅读

[大数据]【数据库系统概论】实验二 SQL数据查询

一、实验目的

1.掌握SQL Server数据库系统基本操作
2.掌握SQL Server数据库系统数据查询使用方法

二、实验内容

利用实验一建立的数据库表,用代码完成以下操作:

  1. 在学生表中增加一个属性”phone”,类型为字符型,长度为11位。
  2. 在学生表中对属性姓名,年龄建立索引,姓名为升序,年龄为降序。
  3. 查询考试不及格的学生和没有参加考试的学生名单。
  4. 查询选修了“C语言”课程的学生名单。
  5. 统计每门课程的平均成绩,按照从高到低排序。
  6. 找出平均成绩最高的学生。
  7. 找出选修了2门课以上的学生。
  8. 查询每位同学高于自己平均分的课程。
  9. 查询全部同学都选修了的课程。
  10. 查询至少选修了学号为“”同学选修全部课程的学生。

数据表:

DROP TABLE IF EXISTS SC;
DROP TABLE IF EXISTS Student;
DROP TABLE IF EXISTS Course;
 
CREATE TABLE Student
 (	
 Sno CHAR(9) PRIMARY KEY,        /* 列级完整性约束条件,Sno是主码*/                  
 Sname CHAR(20) UNIQUE,          /* Sname取唯一值*/
 Ssex CHAR(2),
 Sage SMALLINT,
 Sdept CHAR(20)
 ); 
 
CREATE TABLE  Course
 (	
 Cno CHAR(4) PRIMARY KEY,
 Cname CHAR(40),            
 Cpno CHAR(4),               	                      
 Ccredit SMALLINT,
 FOREIGN KEY (Cpno) REFERENCES  Course(Cno) /* 表级完整性约束条件, Cpno是外码,被参照表是自身*/
 ); 
 
CREATE TABLE  SC
 (
 Sno CHAR(9), 
 Cno CHAR(4),  
 Grade SMALLINT,
 PRIMARY KEY (Sno,Cno),                      /* 主码由两个属性构成,必须作为表级完整性进行定义*/
 FOREIGN KEY (Sno) REFERENCES Student(Sno),  /* 表级完整性约束条件,Sno是外码,被参照表是Student*/
 FOREIGN KEY (Cno)REFERENCES Course(Cno)     /* 表级完整性约束条件,Cno是外码,被参照表是Course*/
 ); 
 
 
INSERT  INTO  Student (Sno,Sname,Ssex,Sdept,Sage) VALUES ('201215121','李勇','男','CS',20);
INSERT  INTO  Student (Sno,Sname,Ssex,Sdept,Sage) VALUES ('201215122','刘晨','女','CS',19);
INSERT  INTO  Student (Sno,Sname,Ssex,Sdept,Sage) VALUES ('201215123','王敏','女','MA',18);
INSERT  INTO  Student (Sno,Sname,Ssex,Sdept,Sage) VALUES ('201215125','张立','男','IS',19);
INSERT  INTO  Student (Sno,Sname,Ssex,Sdept,Sage) VALUES ('201215128','陈冬','男','IS',20);
 

 
INSERT  INTO Course(Cno,Cname,Cpno,Ccredit)	VALUES ('1','数据库',NULL,4);
INSERT  INTO Course(Cno,Cname,Cpno,Ccredit)	VALUES ('2','数学',NULL,2);
INSERT  INTO Course(Cno,Cname,Cpno,Ccredit)	VALUES ('3','信息系统',NULL,4);
INSERT  INTO Course(Cno,Cname,Cpno,Ccredit)	VALUES ('4','操作系统',NULL,3);
INSERT  INTO Course(Cno,Cname,Cpno,Ccredit)	VALUES ('5','数据结构',NULL,4);
INSERT  INTO Course(Cno,Cname,Cpno,Ccredit)	VALUES ('6','数据处理',NULL,2);
INSERT  INTO Course(Cno,Cname,Cpno,Ccredit)	VALUES ('7','Pascal语言',NULL,4);
INSERT  INTO Course(Cno,Cname,Cpno,Ccredit)	VALUES ('8','C语言',NULL,4);

UPDATE Course SET Cpno = '5' WHERE Cno = '1' 
UPDATE Course SET Cpno = '1' WHERE Cno = '3' 
UPDATE Course SET Cpno = '6' WHERE Cno = '4' 
UPDATE Course SET Cpno = '7' WHERE Cno = '5' 
UPDATE Course SET Cpno = '6' WHERE Cno = '7' 

 
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215121 ','1',92);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215121 ','2',85);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215121 ','3',88);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215121 ','8',50);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215122 ','1',50);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215122 ','2',90);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215122 ','3',80);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215123 ','4',59);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215123 ','1',59);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215125 ','1',50);
INSERT  INTO SC(Sno,Cno,Grade) VALUES ('201215128 ','1',60);
 
SELECT * FROM Student;
SELECT * FROM Course;
SELECT * FROM SC;

三、问题和要求

1.写出你操作并正确执行的代码及结果。

image.png
image.png
image.png

1.在学生表中增加一个属性”phone”,类型为字符型,长度为11位。
ALTER TABLE Student ADD phone CHAR(11);
image.png

image.png

2.在学生表中对属性姓名,年龄建立索引,姓名为升序,年龄为降序。
CREATE INDEX INDEXS ON Student(Sname ASC,Sage DESC);
image.png

image.png

3.查询考试不及格的学生和没有参加考试的学生名单。
SELECT DISTINCT S.*,Grade FROM SC,Student S WHERE S.Sno=SC.Sno AND Grade<60;
image.png
4.查询选修了“C语言”课程的学生名单。
SELECT S.*,C.Cname FROM SC,Student S,Course C WHERE S.Sno=SC.Sno AND C.Cno=SC.Cno AND Cname='C语言';
image.png
5.统计每门课程的平均成绩,按照从高到低排序。
SELECT Cname,AVG(Grade) FROM SC,Course C WHERE C.Cno=SC.Cno GROUP BY Cname ORDER BY AVG(Grade) DESC;
image.png
6.找出平均成绩最高的学生。
SELECT TOP 1 Sno 学号, AVG(Grade)平均值 FROM SC GROUP BY Sno
image.png
7.找出选修了2门课以上的学生。
SELECT Sno 学号 FROM SC GROUP BY Sno HAVING COUNT(Cno) >= 2
image.png
8.查询每位同学高于自己平均分的课程。
SELECT * FROM SC S1 WHERE Grade>=(SELECT AVG(Grade) FROM SC S2 WHERE S1.Sno=S2.Sno);
image.png
9.查询全部同学都选修了的课程。
SELECT Cno, Cname FROM Course C WHERE NOT EXISTS
(SELECT * FROM Student S WHERE NOT EXISTS
(SELECT * FROM SC WHERE SC.Cno = C.Cno and SC.Sno = S.Sno));
image.png
10.查询至少选修了学号为 “ 201215122 ” 同学选修全部课程的学生。
SELECT DISTINCT Sno 学号 FROM SC scx WHERE NOT EXISTS(SELECT * FROM SC scy WHERE scy.Sno = '201215122' AND NOT EXISTS(SELECT * FROM SC scz WHERE scz.Sno = scx.Sno AND scz.Cno = scy.Cno));

image.png

  大数据 最新文章
实现Kafka至少消费一次
亚马逊云科技:还在苦于ETL?Zero ETL的时代
初探MapReduce
【SpringBoot框架篇】32.基于注解+redis实现
Elasticsearch:如何减少 Elasticsearch 集
Go redis操作
Redis面试题
专题五 Redis高并发场景
基于GBase8s和Calcite的多数据源查询
Redis——底层数据结构原理
上一篇文章      下一篇文章      查看所有文章
加:2022-10-08 20:48:45  更:2022-10-08 20:49:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 5:41:29-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码