3.数据查询(实验报告)

news2024/11/17 16:33:19

 

目录

一﹑实验目的

二﹑实验平台

三﹑实验内容和步骤

四﹑命令(代码)清单

五﹑调试和测试清单


一﹑实验目的

  1. 掌握使用Transact-SQL的SELECT语句进行基本查询的方法;
  2. 掌握使用SELECT语句进行条件查询的方法;
  3. 掌握SELECT语句的GROUP BY、ORDER BY以及UNION子句的作用和使用方法。
  4. 掌握嵌套查询的方法;
  5. 掌握连接查询的操作方法。

二﹑实验平台

操作系统:Windows xp或Win7

DBMS:SQL Server 2005或SQL Server 2008

三﹑实验内容和步骤

(1)在studentdb数据库中,运行下列SQL语句将输出什么?

① select count(*) from grade

② select substring(姓名,1,2) from student_info

③ select sqrt(分数) from grade where 分数>=85

④ select year(getdate()),month(getdate()),day(getdate())

(2)在studentdb数据库中使用select语句进行基本查询。

①在student_info表中,查询每个学生的学号、姓名和出生日期信息。

②查询学号为’0002’的学生的姓名和家庭住址。

③找出所有男同学的学号和姓名。

(3)使用select语句进行条件查询。

①在grade表中查找分数在70-90范围内的学生的学号和分数。

②在grade表中查询课程编号为0003的学生的平均分。

③在grade表中查询学习各门课程的人数。

④将学生信息按出生日期由大到小顺序排序。

⑤查询所有姓“张”的学生的学号和姓名。

(4)对student_info表,按性别顺序列出学生的学号、姓名、性别、出生日期及家庭住址,性别相同的按学号由小到大顺序排列。

(5)使用group by子句列出各个学生的平均成绩。

(6)使用union运算符将student_info表中姓“张”的学生的学号和姓名与curriculum表的课程编号、课程名称返回在一个表中,且列名为u_编号、u_名称。

(7)嵌套查询

① 在student_info表中查找与“刘卫平”性别相同的所有学生的姓名、出生日期。

② 使用in子查询查找所修课程编号为0002、0005的学生学号、姓名、性别。

③列出学号为0001的学生的分数比学号为0002号的学生的最低分数高的课程编号和分数。

④列出学号为0001的学生的分数比学号为0002号的学生的最高成绩还要高的课程编号和分数。

(8)连接查询。

①查询分数在80-90范围内的学生的学号、姓名和分数信息。

②查询学习“C语言程序设计”课程的学生的学号、姓名和分数。

③查询所有男同学的选课情况,要求列出学号、姓名、课程名称和分数。

④查询每个学生的所选课程的最高成绩,要求列出学号、姓名、课程编号和分数。

⑤查询所有学生的总成绩,要求列出学号、姓名、总成绩,没有选修课程的学生的总成绩为空。

⑥ 为grade表添加数据行:学号为0004、课程编号为0006、分数为76。查询所有课程的选修情况,要求列出课程编号、课程名称、选修人数,curriculum表中没有的课程列值为空。

四﹑命令(代码)清单

2

select 学号,姓名,出生日期 from student_info

select 姓名,家庭住址 from student_info where 学号='0002'

select 学号,姓名 from student_info where 性别='男'

(3)

select 学号,分数 from grade where 分数>=70 and 分数<=90

select avg(分数) from grade where 课程编号='0003'

select 课程编号,count(课程编号)as 学号 from grade
group by 课程编号

select * from student_info
order by 出生日期 desc

select 学号,姓名 from student_info
where 姓名 like '张%'

(4)

select 学号,姓名,性别,出生日期,家庭住址 from student_info
order by 性别,学号

(5)

select 学号,avg(分数)平均成绩 from grade group by 学号

(6)

select 学号 u_编号,姓名 u_名称 from student_info where 姓名 like '张%'
union
select 课程编号,课程名称 from curriculum

(7)

select 姓名,出生日期 from student_info where
性别=(select 性别 from student_info where 姓名='刘卫平')

select 学号,姓名,性别 from student_info where
学号 in(select 学号 from grade where 课程编号 in ('0002','0005'))

select 课程编号,分数 from grade where
学号='0001'and 分数>(select min(分数) from grade where 学号='0002')

select 课程编号,分数 from grade where
学号='0001'and 分数>(select max(分数) from grade where 学号='0002')

(8)

select grade.学号,姓名,分数 from grade,student_info where
grade.学号=student_info.学号 and (分数 between 80 and 90)

select grade.学号,姓名,分数 from grade,student_info,curriculum where
grade.学号=student_info.学号 and curriculum.课程编号=grade.课程编号
and 课程名称='C语言程序设计'

select grade.学号,姓名,课程名称,分数 from grade,student_info,curriculum where
grade.学号=student_info.学号 and curriculum.课程编号=grade.课程编号
and 性别='男'

select grade.学号,姓名,课程编号,分数 from grade,student_info where
grade.学号=student_info.学号 and 分数 in(select max(分数) from grade group by 学号)

select student_info.学号,姓名,总成绩
from student_info left outer join
(select 学号,sum(分数)as 总成绩 from grade group by 学号)
grade on student_info.学号=grade.学号

insert into grade values('0004','0006',76,null)

select curriculum.课程编号,课程名称,选修人数
from curriculum right outer join
(
select 课程编号,count(*)as 选修人数
from grade group by 课程编号
)
grade on curriculum.课程编号=grade.课程编号

五﹑调试和测试清单

1

 

 

(2)

(3)

(4)

(5)

(6)

(7)

(8)

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/492963.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MX6U根文件系统配置

编译 BusyBox 构建根文件系统 /home/ /linux/nfs mkdir rootfs tar -vxjf busybox-1.29.0.tar.bz2 依照自己的交叉编译 不然会出错 配置好 busybox 以后就可以编译了&#xff0c;我们可以指定编译结果的存放目录&#xff0c;我们肯定要将编 译结果存放到前面创建的 rootfs 目录…

(leetcode)66. 加一 67. 二进制求和(详解)

目录 66. 加一 思路 代码 67. 二进制求和 思路 代码 66. 加一 给定一个由 整数 组成的 非空 数组所表示的非负整数&#xff0c;在该数的基础上加一。 最高位数字存放在数组的首位&#xff0c; 数组中每个元素只存储单个数字。 你可以假设除了整数 0 之外&#xff0c;这…

7个最好的WordPress LMS在线学习管理系统比较

您是否正在为您的 WordPress 网站寻找最好的 LMS 在线学习管理系统插件&#xff1f; 学习管理系统 (LMS) 插件允许您创建和运行类似 Udemy 和 LearnDesk 等在线课程。一个完美的 WordPress LMS 插件拥有您管理在线课程、运行和评分测验、接受付款等所需的一切。 在本文中&…

【MySql】数据库 select 进阶

数据库 数据库表的设计ER 关系图三大范式 聚合函数与分组查询聚合函数 (count、sum、avg、max、min)分组查询 group by fields....having....(条件) 多表联查内连接外连接&#xff08;左连接&#xff0c;右连接&#xff09;自连接子查询合并查询 UNION 数据库表的设计 ER 关系…

在Centos中metabase安装与配置(bi工具)

1 metabase介绍 metabase是一款开源的BI分析工具&#xff0c;开发语言clojureReact为主、也有高阶的收费版。 官网&#xff1a;https://www.metabase.com/ 可以利用Metabase进行数据分析&#xff0c;数据可视化&#xff0c;报表生成等。开源地址&#xff1a;https://github.co…

(五)【平衡小车制作】位置式PID、直立环与速度环概念

声明&#xff1a;本博客是B站视频【天下行走的平衡小车视频】的笔记 一、PID控制算法概念 PID控制&#xff0c;即为对偏差进行比例、积分和微分控制。由三个元素构成:比例&#xff08;P&#xff09;&#xff0c;积分&#xff08;I&#xff09;&#xff0c;微分&#xff08;D&…

Linux系统应用编程(六)Linux网络编程(下篇)

本篇主要内容&#xff1a; 一、Linux的文件描述符二、多路IO转接&#xff08;上&#xff09;1.基础版多路IO转接select▶ 关于select( )函数▶ select( )改写上篇案例 2.加强版多路IO转接poll3.顶配版多路IO转接epoll▶ epoll相关函数&#xff08;1&#xff09;创建监听红黑树&…

重装系统后,MySQL install错误,找不到dll文件,或者应用程序错误

文章目录 1.找不到某某dll文件2.mysqld.exe - 应用程序错误使用DX工具直接修复 1.找不到某某dll文件 由于找不到VCRUNTIME140_1.dll或者MSVCP120.dll&#xff0c;无法继续执行代码&#xff0c;重新安装程序可能会解决此问题。 在使用一台重装系统过的电脑&#xff0c;再次重新…

Yolov8实战:交通roadsign识别,通过加入CVPR203 DCNV3和BiLevelRoutingAttention,暴力涨点

1.roadsign数据集介绍 数据集大小&#xff1a;877张 类别&#xff1a;speedlimit、crosswalk、trafficlight、stop 2.基于YOLOV8的roadsign识别 2.1 原始yolov8性能分析 原始map为0.841 2.1 加入DCNV3 博客地址&#xff1a; https://cv2023.blog.csdn.net/article/detai…

手写 EventBus:从零到一实现自己的事件总线库

简介&#xff1a;在本文中&#xff0c;我们将详细介绍如何从头开始实现一个轻量级的 EventBus 库。我们将以 XEventBus 为例&#xff0c;阐述整个实现过程&#xff0c;以及在实现过程中遇到的关键问题和解决方法。 一 引言 什么是 EventBus&#xff1f; EventBus 是一个基于…

C++ 多线程编程(三) 获取线程的返回值——future

C11标准库增加了获取线程返回值的方法&#xff0c;头文件为<future>&#xff0c;主要包括future、promise、packaged_task、async四个类。 那么&#xff0c;了解一下各个类的构成以及功能。 1 future future是一个模板类&#xff0c;它是传输线程返回值&#xff08;也…

2-Lampiao百个靶机渗透(精写-思路为主)框架漏洞利用2

特别注明&#xff1a;本文章只用于学习交流&#xff0c;不可用来从事违法犯罪活动&#xff0c;如使用者用来从事违法犯罪行为&#xff0c;一切与作者无关。 文章目录 前言一、环境重新部署二、AWVSxray联动和xraybs联动1.安装AWVSxray2.让xray和bs先联动3.AWVS和xray联动 三、p…

【Spring框架全系列】如何创建一个SpringBoot项目

&#x1f307;哈喽&#xff0c;大家好&#xff0c;我是小浪。前几篇博客我们已经介绍了什么是Spring&#xff0c;以及如何创建一个Spring项目&#xff0c;OK&#xff0c;那么单单掌握Spring是完全不够的&#xff0c;Spring的家族体系十分强大&#xff0c;我们还需要深入学习&am…

力扣---LeetCode160. 相交链表(代码详解+流程图)

文章目录 前言160. 相交链表链接&#xff1a;思路&#xff1a;方法一&#xff1a;暴力求解法1.1 时间复杂度&#xff1a;O(M*N)1.2 代码&#xff1a; 方法二&#xff1a;双指针2.1 时间复杂度&#xff1a;O(N)2.2 代码&#xff1a;2. 3流程图&#xff1a; 注意&#xff1a;补充…

13. Transformer(下)

P33 Transformer&#xff08;下&#xff09; 视频链接 P33 Transformer&#xff08;下&#xff09; 1. Decoder: Autoregressive(AT) Decoder原理&#xff1a; Encoder vs Decoder&#xff1a; Masked&#xff1a; how to stop&#xff1a; 2. Decoder: Non-autoregressive(…

网络基础——网络的发展史

作者简介&#xff1a;一名计算机萌新、前来进行学习VUE,让我们一起进步吧。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;我叫于豆豆吖的主页 目录 前言 一.网络发展史 1. ARPANET 2.TCP/IP协议 3. 互联网 4.Web浏览器 5.搜索引擎 6. 社交网…

如果你访问了某个网站,又不想让人知道怎么办?

问大家一个问题&#xff1a;如果你访问了某个网站&#xff0c;又不想让人知道怎么办&#xff1f; 你可能会说&#xff0c;把浏览器浏览历史记录清除&#xff0c;或者直接用无痕模式。 如果你只能想到这一层&#xff0c;那只能说图young&#xff01; 这么说吧&#xff0c;理论…

操作系统原理 —— 调度的概念、层次(十一)

调度的基本概念 在操作系统中的调度&#xff0c;是指操作系统从就序队列中选择一个作业&#xff0c;或者进程进行执行。 举个例子&#xff1a; 比如我们去银行窗口排队&#xff0c;排队的人就相当于就绪列表&#xff0c;窗口就相当于是操作系统&#xff0c;窗口需要服务排队…

npm的使用和命令

3.0 npm 什么是npm 是node管理包的工具 3.1 初始化包管理描述文件 package.json npm init // 会询问你每次的选项 或 npm init -y // 不询问你选项&#xff0c;默认就是确定 首先建立一个文件在路径里面全选写cmd 然后打开环境 在里面写npm init -y回车 就会在你原来空的文…

编写用户帮助/操作手册指南

背景&#xff1a; 用户操作手册是一份指导用户使用产品或服务的重要手册。 一个新系统&#xff0c;需要写用户操作手册&#xff0c;该从何下笔&#xff1f;本篇是一篇教你编写用户帮助/操作手册的指南&#xff5e; 首先&#xff0c;先来看一个反例 &#xff1a; 这个是我入职…