0

0

数据库上机试验(三)

php中文网

php中文网

发布时间:2016-06-07 15:11:44

|

3910人浏览过

|

来源于php中文网

原创

这是第三次上机内容以及结果,本次的程序是基于第二次上机时候的建立好的表。所有完整代码在我空间的代码库中均存放,可以直接运行。 上机实验五 SELECT语句的使用(二) 一、实习目的 掌握SELECT语句的嵌套使用方法,能适用SQL Server对表作复杂查询。 二、

     这是第三次上机内容以及结果,本次的程序是基于第二次上机时候的建立好的表格。所有完整代码在我空间的代码库中均存放,可以直接运行。

     

上机实验五 SELECT语句的使用(二)

一、实习目的

掌握SELECT语句的嵌套使用方法,能适用SQL Server对表作复杂查询。

二、实习准备

1.复习SELECT语句较高级格式的使用。

2.了解集合函数在分组查询中的使用规则。

三、实验内容

使用嵌套查询和表的连接查询分别完成以下查询语句:

(1) 找出与李勇在同一个班级的学生信息。

(2) 找出所有与李勇有相同选修课的学生信息。

(3) 找出年龄介于学生李勇和25岁之间的学生信息。

(4) 找出选修了课程操作系统的学生学号和姓名。

(5) 找出所有没有选修1号课程的学生姓名。

(6) 找出选修了全部课程的学生姓名。

完成以下查询:

(1) 查询选修了3号课程的学生学号及其成绩,并按成绩的降序排列。

(2) 查询全体学生信息,要求查询结果按班级号升序,同一班级学生按年龄降序排列。

(3) 求每个课程号相应的选课人数。

(4) 查询选修了3门以上课程的学生学号。

 

四、实习报告内容

云网OA
云网OA

采用JSP开发的办公自动化产品、基于B/S结构,运行环境:JDK v1.5、Tomcat v5.5、MySQL v4.1,三者均为以上版本其他相关内容:可视化流程设计: 流程支持串签、会签和分支流程,可以设置流程节点的修改、删除权限,并可指定流程中各个用户在表单中可以填写的域。智能表单所见即所得设计: 智能设计,自动在数据库中生成表格,方便优化程序 公共交流: 集论坛、博客、聊天室于一体文件柜:C

下载

    1.写出上述操作的SQL语句。

2.使用存在量词[NOT] EXISTS的嵌套查询时,何时外层查询的WHERE条件为真,何时为假?

3.当既能用连接查询又能用嵌套查询时,应该选择哪种比较好?为什么?

 

上机实验六 SQL的存储操作

一、实习目的

掌握用交互式SQL语句对已建基本表进行存储操作:修改,删除,插入,加深对数据的完整性的理解。

二、实习准备

1.复习数据的完整性,在进行数据的修改、删除、插入时,要注意保证数据的一致性。

2.复习UPDATE、DELETE、INSERT语句与子查询的结合使用。

三、实习内容

完成以下查询语句:

(1) 对每个班,求学生的平均年龄,并把结果存入数据库。

(2) 将01311班的全体学生的成绩置零。

(3) 删除2001级计算机软件班全体学生的选课记录。

(4) 学生李勇已退学,从数据库中删除有关他的记录。

四、实习报告内容

1.写出上述操作的SQL语句。

2.DROP和DELETE命令的本质区别是什么?


运行代码:

/*************上机试验五************************/
/**找出与李勇在同一个班级的学生信息**/
SELECT Sno '学号',Sname '姓名',Ssex '性别',Sage '年龄',Clno '班级'
FROM Student 
WHERE Clno = 
(SELECT Clno 
FROM Student 
WHERE Sname = '李勇');

/**找出所有与李勇有相同选修课的学生信息**/
SELECT * 
FROM Student
 WHERE Sno IN 
(SELECT Sno
FROM Grade 
WHERE Cno IN
(SELECT Cno 
FROM Grade 
WHERE Sno IN
(SELECT Sno
FROM Student
 WHERE Sname='李勇')));
 
/**找出年龄介于学生李勇和25岁之间的学生信息**/
SELECT * 
FROM Student 
WHERE Sage BETWEEN 
(SELECT Sage 
FROM Student 
WHERE Sname = '李勇') AND 25;


/**找出所有没有选修1号课程的学生姓名**/
SELECT Sname '姓名' 
FROM Student 
WHERE Sno NOT IN
(SELECT Sno 
FROM Grade 
WHERE Cno = '1');

/**找出选修了全部课程的学生姓名**/
SELECT Sname
FROM Student
WHERE NOT EXISTS(SELECT *
         FROM Course
         WHERE NOT EXISTS (SELECT *
                   FROM Grade
                   WHERE Student.Sno=Grade.Sno and Course.Cno=Grade.Cno));
                   
 /**查询选修了3号课程的学生学号及其成绩,并按成绩的降序排列**/
 SELECT Sno '学号', Gmark '成绩' 
 FROM Grade 
 WHERE Cno = '3' ORDER BY Gmark DESC;


/**查询全体学生信息,要求查询结果按班级号升序,同一班级学生按年龄降序排列**/
SELECT * 
FROM Student
ORDER BY Clno,Sage DESC;


/**求每个课程号相应的选课人数**/
SELECT Cno '课程号',COUNT(*) '选课人数'
FROM Grade 
GROUP BY Cno;


/**查询选修了3门以上课程的学生学号**/
SELECT Sno 
FROM Grade 
GROUP BY Sno HAVING COUNT(*)>3;


/**********上机作业六***************/
/**对每个班,求学生的平均年龄,并把结果存入数据库**/
/*第一种方法建立新的数据库*/
DROP TABLE Savage;
CREATE TABLE Savage(
Clno Char(5) NOT NULL,
Avage Smallint
);
INSERT INTO Savage(Clno,Avage)
SELECT Clno,AVG(Sage)
FROM Student
GROUP BY Clno; 
/*第二种方法在Class表中新建一个属性列*/  /*一直出错误,错在哪了。。。*/
/*ALTER TABLE Class add Avage Smallint;
UPDATE Class 
SET Avage = AVG(Sage)
FROM Class,Student
GROUP BY Clno HAVING Student.Clno =Class.Clno;*/  

/**将01311班的全体学生的成绩置零**/
UPDATE Grade
SET Gmark=0
WHERE Sno IN
(SELECT Sno
FROM Student 
WHERE Clno = '01311');


/**删除2001级计算机软件班全体学生的选课记录**/
DELETE 
FROM Grade
WHERE Sno IN
(SELECT Sno 
FROM Student 
WHERE Clno = (
SELECT Clno 
FROM Class 
WHERE Speciality = '计算机软件' AND Inyear = '2001'));


/**学生李勇已退学,从数据库中删除有关他的记录**/
  /*受影响的表为Class Grade Student (新建的Savage 表先不考虑)*/
UPDATE Class
SET Number = Number-1
WHERE Clno = 
(SELECT Clno 
FROM Student
WHERE Sname = '李勇');
DELETE
FROM Grade
WHERE Sno = 
(SELECT Sno 
FROM Student 
WHERE Sname = '李勇');
DELETE
FROM Student
WHERE Sname = '李勇';

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
AO3官网入口与中文阅读设置 AO3网页版使用与访问
AO3官网入口与中文阅读设置 AO3网页版使用与访问

本专题围绕 Archive of Our Own(AO3)官网入口展开,系统整理 AO3 最新可用官网地址、网页版访问方式、正确打开链接的方法,并详细讲解 AO3 中文界面设置、阅读语言切换及基础使用流程,帮助用户稳定访问 AO3 官网,高效完成中文阅读与作品浏览。

45

2026.02.02

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

8

2026.02.02

Golang WebAssembly(WASM)开发入门
Golang WebAssembly(WASM)开发入门

本专题系统讲解 Golang 在 WebAssembly(WASM)开发中的实践方法,涵盖 WASM 基础原理、Go 编译到 WASM 的流程、与 JavaScript 的交互方式、性能与体积优化,以及典型应用场景(如前端计算、跨平台模块)。帮助开发者掌握 Go 在新一代 Web 技术栈中的应用能力。

4

2026.02.02

PHP Swoole 高性能服务开发
PHP Swoole 高性能服务开发

本专题聚焦 PHP Swoole 扩展在高性能服务端开发中的应用,系统讲解协程模型、异步IO、TCP/HTTP/WebSocket服务器、进程与任务管理、常驻内存架构设计。通过实战案例,帮助开发者掌握 使用 PHP 构建高并发、低延迟服务端应用的工程化能力。

3

2026.02.02

Java JNI 与本地代码交互实战
Java JNI 与本地代码交互实战

本专题系统讲解 Java 通过 JNI 调用 C/C++ 本地代码的核心机制,涵盖 JNI 基本原理、数据类型映射、内存管理、异常处理、性能优化策略以及典型应用场景(如高性能计算、底层库封装)。通过实战示例,帮助开发者掌握 Java 与本地代码混合开发的完整流程。

3

2026.02.02

go语言 注释编码
go语言 注释编码

本专题整合了go语言注释、注释规范等等内容,阅读专题下面的文章了解更多详细内容。

62

2026.01.31

go语言 math包
go语言 math包

本专题整合了go语言math包相关内容,阅读专题下面的文章了解更多详细内容。

55

2026.01.31

go语言输入函数
go语言输入函数

本专题整合了go语言输入相关教程内容,阅读专题下面的文章了解更多详细内容。

27

2026.01.31

golang 循环遍历
golang 循环遍历

本专题整合了golang循环遍历相关教程,阅读专题下面的文章了解更多详细内容。

33

2026.01.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.3万人学习

Django 教程
Django 教程

共28课时 | 3.8万人学习

Excel 教程
Excel 教程

共162课时 | 15.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号