MySQL-实验-单表、多表数据查询和嵌套查询

目录

0.简单子查询

(1)带比较运算符的子查询

(2)关键字子查询

1.多表查询

3.子查询

4.多表子查询


0.简单子查询

(1)带比较运算符的子查询

在右侧编辑器补充代码,查询大于所有平均年龄的员工姓名与年龄。

我们为你提供了tb_emp表,数据如下:

idnameage
1Mary23
2Allen21
3kevin25
4Tom33
5Nancy28
select name,age from tb_emp where age>=
(select avg(age) from tb_emp);

(2)关键字子查询

 我们为你提供了如下数据表: tb_salary表数据:

idpositionsalary
1Java8000
2Java8400
3Java9000
4Python6500
5Python10000

根据提供的数据,在右侧编辑器中补充代码:

  1. 查询薪资表中比Java最高工资高的所有员工职位名称和薪资;

select `position`,salary 
from tb_salary 
where salary>ALL(select salary from tb_salary where `position`='Java'); 
  1. 查询薪资表中比Java最低工资高的所有员工职位名称和薪资;

select `position`,salary 
from tb_salary 
where salary>ANY(select salary from tb_salary where `position`='Java');
  1. 查询薪资表中职位为Java的所有员工职位名称和薪资。

select `position`,salary from tb_salary where `position`='Java';

1.多表查询

打开library数据库

第一题 根据读者(reader)和借阅(borrow)数据表,查询王颖珊的借阅记录,

包括条形码txm、借阅日期jyrq、还书日期hsrq

select txm,jyrq,hsrq 
from reader,borrow 
where reader.dzzh=borrow.dzzh and reader.xm='王颖珊';

第二题  根据图书(book)和借阅(borrow)数据表,查询李白全集被借阅的情况:

包括读者证号dzzh、借阅日期jyrq、还书日期hsrq

select dzzh,jyrq,hsrq 
from book,borrow 
where book.txm=borrow.txm and book.sm='李白全集';

第三题 根据读者(reader)、图书(book)和借阅(borrow)数据表查询没有被归还的借阅信息:

包括读者证号dzzh、姓名xm、电话dhhm、条形码txm、书名sm、借阅日期jyrq

提示:通过isnull(表达式)可以判断表达式是否NULL值

select reader.dzzh,xm,dhhm,book.txm,sm,jyrq 
from reader,book,borrow 
where reader.dzzh=borrow.dzzh and book.txm=borrow.txm and isnull(hsrq);

2.多表查询及统计分组

根据数据表图书、读者和借阅,实现多表查询及对查询分组统计

为了完成本关任务,你需要掌握:

第一题  统计每本书借阅的次数,显示书名和借阅次数(借阅次数命名为jycs),按借阅次数降序排列,借阅次数相同的按书名降序排列

(提示:borrow数据表的一条数据对应一次借阅)

-- 方法1
select sm,jycs 
from book inner join 
     (select txm,count(jyrq)jycs from borrow group by txm)a 
on book.txm=a.txm order by jycs desc,sm desc;

-- 方法2
select sm,count(sm)as jycs 
from borrow left join book on book.txm=borrow.txm 
group by sm 
order by jycs desc,sm desc;

第二题  统计借阅次数在2次以上的图书的借阅的次数,显示书名和借阅次数,按借阅次数降序排列,借阅次数相同的按书名降序排列

-- 方法1
select sm,jycs from book inner join
    (select txm,count(jyrq)jycs from borrow group by txm)a
on book.txm=a.txm and jycs>=2  order by jycs desc,sm desc;

-- 方法2
select sm,count(sm) as jycs  from borrow left join book on book.txm=borrow.txm 
group by sm having(jycs>=2)
order by jycs desc,sm desc;

第三题  统计每个出版社的图书的借阅次数,显示出版社的名称和借阅次数,按借阅次数降序排列,借阅次数相同的按出版社降序排列

-- 方法1
select cbs,count(cbs)jycs 
from borrow left join book
on book.txm=borrow.txm 
group by cbs
order by jycs desc,cbs desc;

--方法2
select cbs,count(cbs) as jycs 
from borrow left join book on book.txm=borrow.txm 
group by cbs
order by jycs desc,cbs desc;

第四题  统计每位读者借阅的次数,显示姓名和借阅次数,按借阅次数降序排列,借阅次数相同的按姓名降序排列

-- 方法1
select  xm,jycs from reader inner join
(select dzzh,count(jyrq)jycs from borrow group by dzzh)a
on reader.dzzh=a.dzzh order by jycs desc,xm desc;

-- 方法2
select xm,count(xm)jycs from borrow left join reader on borrow.dzzh=reader.dzzh 
group by xm
order by jycs desc,xm desc;

第五题  统计研究生读者借阅的次数,显示姓名和借阅次数,按借阅次数降序排列,借阅次数相同的按姓名降序排列

-- 方法1 
select xm,jycs from reader inner join
 (select dzzh,count(jyrq)jycs from borrow group by dzzh)a 
 on reader.dzzh=a.dzzh and sf='研究生' order by jycs desc,xm desc;

-- 方法2
select xm,count(xm) as jycs 
from borrow left join reader on borrow.dzzh=reader.dzzh 
where sf='研究生'
group by xm
order by jycs desc,xm desc;

注意:order by <表达式1>,<表达式2> 表示首先按第一个表达式的值排序,第一个表达式的值相同的再按第二个表达式的值排序

3.子查询

第一题 查询与李白全集同一个出版社的图书的书名(不包括李白全集)

-- 方法1
select sm from book 
where cbs=(select cbs from book where sm='李白全集') and sm<>'李白全集';

-- 方法2
select sm from book where cbs="上海古籍出版社" and sm!="李白全集";

第二题 查询高于图书的平均售价(sj)的图书的书名和售价

select sm,sj from book where sj>=(select avg(sj) from book);

第三题 查询售价最高的图书的条形码、书名和售价

select txm,sm,sj from book where sj=(select max(sj) from book);

第四题 查询售价最低的图书的条形码、书名和售价

select txm,sm,sj from book where sj=(select mix(sj) from book);

4.多表子查询

第一题 查询曾经借过图书的读者的读者证号和姓名

-- 方法1
select distinct dzzh,xm 
from reader inner join borrow using(dzzh) order by dzzh;

-- 方法2
select dzzh,xm from reader where reader.dzzh in (select dzzh from borrow);

第二题 查询曾经没有被借阅的图书的条形码和书名

select txm,sm from book where txm not in(select txm from borrow);

第三题 查询与孙思旺借过相同图书的读者的读者证号和姓名,按读者证号升序排列

-- 方法1
select distinct reader.dzzh,xm 
from reader,borrow 
where reader.dzzh=borrow.dzzh and xm<>'孙思旺' and txm in
    (select txm from reader,borrow 
    where reader.dzzh=borrow.dzzh and xm='孙思旺');


-- 方法2
select dzzh,xm 
from reader 
where reader.dzzh in 
    (select dzzh from borrow 
    where txm in (select txm from borrow 
                  where borrow.dzzh=(select dzzh from reader 
                                     where xm='孙思旺')
                  )
     ) 
and dzzh!='006' order by dzzh asc;

第四题 查询借阅过李白全集的读者所借过的其他图书的书名 按书名升序排列

-- 方法1
select distinct sm 
from book,borrow 
where book.txm=borrow.txm and sm<>'李白全集' and dzzh in 
     (select dzzh from book,borrow where sm='李白全集' and book.txm=borrow.txm)
order by sm;

-- 方法2
select sm from book 
where book.txm in 
    (select txm from borrow
     where borrow.dzzh in (select dzzh from borrow 
                           where borrow.txm=(select txm from book 
                                             where sm="李白全集")
                           )
     )
and sm!="李白全集" order by sm asc;

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

10 SQL进阶 -- 综合练习题 -- 10道经典SQL题目,配套数据与解答

1. 创建表结构和导入数据 1.1 新建数据库 1.2 执行建表语句 点击下方链接直接下载创建数据表脚本:http://tianchi-media.oss-cn-beijing.aliyuncs.com/dragonball/SQL/create_table.sql 执行建表语句执行成功查看创建的表1.3 导入数据 点击下方链接直接下载插入数据脚本:htt…

VBA脚本终章编译器崩溃

一、介绍 本篇文章为VBA脚本隐藏技术的最后一篇&#xff0c;将介绍如何在保证VBA脚本正常执行的情况下&#xff0c;使分析人员无法打开编译器。 那么为什么需要分析人员无法打开编译器呢&#xff1f; 首先&#xff0c;我们需要引入一个知识点。 在上篇《VBA隐藏技术stompin…

笔记本wifi连接外网 网线连接办公内网 设置路由实现内外网可同时访问

工作提供的办公网络是企业内网,接上企业内网网线后 通过无线在连接手机wifi ,会发现内外网无法同时访问,我自己电脑是接上内网网线 也是只能访问外网,除非把外网无线暂时关闭,才可以访问内网 频繁切换很不方便 1.查看外网无线 wifi网卡信息 IPv4 地址: 192.168.18.114 IP…

数据结构学习记录

数据结构 数组 & 链表 相连性 | 指向性 数组可以迅速定位到数组中某一个节点的位置 链表则需要通过前一个元素指向下一个元素&#xff0c;需要前后依赖顺序查找&#xff0c;效率较低 实现链表 // head > node1 > node2 > ... > nullclass Node {constructo…

AI原生时代,操作系统为何是创新之源?

一直以来&#xff0c;操作系统都是软件行业皇冠上的明珠。 从上世纪40、50年代&#xff0c;汇编语言和汇编器实现软件管理硬件&#xff0c;操作系统的雏形出现&#xff1b;到60年代&#xff0c;高级编程语言和编译器诞生&#xff0c;开发者通过操作系统用更接近人的表达方式去…

面向对象(一)

一.类与对象的定义 (1)类(设计图):是对象共同特征的描述: (2)对象:是真实存在的具体东西。 在Java中,必须先设计类&#xff0c;才能获取对象。 二.如何定义类 public class 类名{1.成员变量(代表属性,一般是名词) 2.成员方法(代表行为,一般是动词) 3.构造器 4.代码块 5.内部…

Liunx入门学习 之 基础操作指令讲解(小白必看)

股票的规律找到了&#xff0c;不是涨就是跌 一、Linux下基本指令 1.ls 指令 2.pwd 命令 3.cd 指令 4.touch 指令 5.mkdir 指令 6.rmdir指令 && rm 指令 7.man 指令 8.cp 指令 9.mv指令 10.cat 11.more 指令 12.less 指令 13.head 指令 14.tail 指令 15…

论文解读-Contiguitas: The Pursuit of Physical Memory Contiguity in Datacenters

研究背景&#xff1a; 在内存容量飞速增长的背景下&#xff0c;使用小页管理内存会带来巨大的内存管理开销&#xff08;地址转换开销高&#xff09;。近些年来不少研究尝试给应用分配大段连续区域&#xff0c;或者改善页表结构&#xff08;如使用hash结构的页表&#xff09;以降…

质谱原理与仪器2-笔记

质谱原理与仪器2-笔记 常见电离源电子轰击电离源(EI)碎片峰的产生典型的EI质谱图 化学电离源(CI)快原子轰击源(FAB)基体辅助激光解析电离(MALDI)典型的MALDI质谱图 大气压电离源(API)电喷雾离子源(ESI)大气压化学电离源(APCI)APCI的正负离子模式 大气压光电离源(APPI) 常见电离…

玄子Share-计算机网络参考模型

玄子Share-计算机网络参考模型 分层思想 利用七层参考模型&#xff0c;便于在网络通信过程中&#xff0c;快速的分析问题&#xff0c;定位问题并解决问题 将复杂的流程分解为几个功能相对单一的子过程 整个流程更加清晰&#xff0c;复杂问题简单化 更容易发现问题并针对性的…

线上频繁fullgc问题-SpringActuator的坑

整体复盘 一个不算普通的周五中午&#xff0c;同事收到了大量了cpu异常的报警。根据报警表现和通过arthas查看&#xff0c;很明显的问题就是内存不足&#xff0c;疯狂无效gc。而且结合arthas和gc日志查看&#xff0c;老年代打满了&#xff0c;gc不了一点。既然问题是内存问题&…

Python练习03

题目 解题思路 Demo58 通过字符串切片来进行反转操作 def _reverse():"""这是一个反转整数的函数"""num input("请输入想要反转的整数")print(num[::-1]) 运行结果 Demo61 首先制作一个判断边长的函数&#xff0c;通过三角形两边…

又成长了,异常掉电踩到了MySQL主从同步的坑!

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是【IT邦德】&#xff0c;江湖人称jeames007&#xff0c;10余年DBA及大数据工作经验 一位上进心十足的【大数据领域博主】&#xff01;&#x1f61c;&am…

Google Earth Engine 洪水制图 - 使用 Sentinel-1 SAR GRD

Sentinel-1 提供从具有双极化功能的 C 波段合成孔径雷达 (SAR) 设备获得的信息。该数据包括地面范围检测 (GRD) 场景,这些场景已通过 Sentinel-1 工具箱进行处理,以创建经过校准和正射校正的产品。该集合每天都会更新,新获得的资产会在可用后两天内添加。 该集合包含所有 G…

《王者荣耀》Hello Kitty 小兵皮肤完整设置指南

王者荣耀与三丽鸥的联动活动上线了 Hello Kitty 小兵皮肤&#xff0c;让我们的峡谷小兵们也能穿上漂亮的衣服啦&#xff01;这款皮肤极具卡哇伊风格&#xff0c;引起了许多玩家的关注。许多小伙伴都想知道如何使用这款 Hello Kitty 小兵皮肤&#xff0c;今天小编将为大家整理出…

STC单片机与串口触摸屏通讯程序

/***串口1切换通讯测试,单片机发送数据给触摸屏***/ /***切换到3.0 3.1发送数据到串口通信软件 ***/ /***设置温度 加热时间读写EEPROM正确 ***/ #include <REG52.H> //2023 3 5 L330 CODE2667 #include <intrin…

使用JDK自带工具进行JVM内存分析之旅

进行jvm内存分析可以排查存在和潜在的问题。 通过借助jdk自带的常用工具&#xff0c;可以分析大概可能的问题定位以及确定优化方向。 JVM内存分析有很多好处。 内存泄漏排查&#xff1a;JVM 内存泄漏是指应用程序中的对象占用的内存无法被垃圾回收器释放&#xff0c;导致内存…

遥瞻智慧:排水系统远程监控的卓越解决方案

遥瞻智慧&#xff1a;排水系统远程监控的卓越解决方案 在城市脉络的深层肌理中&#xff0c;排水系统犹如一条条隐秘的生命线&#xff0c;默默承载着城市的呼吸与律动。然而&#xff0c;如何以科技之眼&#xff0c;赋予这些无形网络以实时感知、精准调控的能力&#xff0c;使之…

基于机器学习的车辆状态异常检测

基于马氏距离的车辆状态异常检测&#xff08;单一传感器&#xff09; 基于多元自动编码器的车辆状态异常检测 基于单传感器平滑马氏距离的车辆状态异常检测 工学博士&#xff0c;担任《Mechanical System and Signal Processing》等期刊审稿专家&#xff0c;擅长领域&#xff1…

数据分析场景,连号相关业务

连号相关业务 业务场景&#xff1a;现在需要从a列一堆编号中&#xff0c;将连号范围在10以内的数据分别分成一组。 先看实先效果 演示的为db2数据库&#xff0c;需要含有窗口函数&#xff0c;或者可以获取到当前数据偏移的上一位数据 第一步&#xff1a;将A列数据正序第二步…