Linux运维:mysql高级查询语句(2)

目   录

一、创建数据库:

二、创建表结构:DDL

2.1 学生表s:

2.2 成绩表sc:

2.3 课程表c:

三、录入数据:DML

3.1 对学生表s的数据录入:

3.2 对成绩表sc的数据录入:

3.3 对课程表c的数据录入:

3.4 通过插入数据,有以下三张表:

四、查询:

4.1 同时选修了c04和c05的同学的学号

4.2 查询选修了“高等数学”的学生的学号和姓名

4.2.1 嵌套查询,多表查询(三张表)

4.2.2 连接三张表

4.3 查询没有选课的学生的学号和姓名

4.4 查找只有男同学选修的课程的课程号

4.5 查询年龄比“吴俊”大的男同学的学号和年龄

4.6 查询选修了"c04"课程的学生中,成绩比”李露“高的学生的学号和成绩

4.7 查询和“孙晓英”在同一个班级的学生的学号、姓名和所在班级

4.8 查询学生表中比“19电商1”班所有学生年龄都小的学生的学号和年龄

4.9 查询学生表中比“19电商1”班某个学生年龄小的学生的学号和年龄

4.10 查询选修c04成绩最高分学生的学号和成绩

4.11 聚合函数

4.11.1 count计数

4.11.2 去重计数

4.11.3 求和

4.11.4 最高分

4.11.5 平均值


现有教务管理系统的数据库。存放学生的信息。创建数据库jwgl。创建三张表:学生表s,课程表c,成绩表sc。安装数据库,使用图形化界面navicat。

一、创建数据库:

create database jwgl;

二、创建表结构:DDL

2.1 学生表s:

create table s(
        sno varchar(8) primary key,
        sname varchar(10),
        ssex varchar(5),
        sage int,
        sclass varchar(10),
        jg varchar(10)
);

 选中,右击,运行已选择的。

2.2 成绩表sc:

create table sc (
        sno varchar(10),
        cno varchar(10),
        score int
);

2.3 课程表c:

create table c (
        cno varchar(5) primary key,
        cname varchar(255),
        precid varchar(255),
        cpro varchar(255),
        credit int
);

2.4 查看表结构:

desc s;     desc sc;     desc c;

三、录入数据:DML

3.1 对学生表s的数据录入:

varchar类型的要用引号引起来

insert into 插入数据,s是表,values是值。如果给某些字段添加值(主键必须有值),那么:

insert into s(字段1,字段2) values(字段1的值,字段2的值);  要一一对应起来,如果s表中不写字段,那么值values中必须添加所有的值。

查看select * from s;

3.2 对成绩表sc的数据录入:

insert into sc values("060101","c01",91);

查看表数据:select * from sc;

3.3 对课程表c的数据录入:

insert into c values("c01","高等数学","","公共必修",4);

查看表数据:select * from c;

3.4 通过插入数据,有以下三张表:

学生表:

成绩表:

课程表:

四、查询:

4.1 同时选修了c04和c05的同学的学号

分析:查询的结果是显示学号,课程号和学号,是要在成绩表中查询,并且是选修了c04和c05课程的学号。查出学号,所以是select sno。可以先查出选修了c04课程的学号,且(and)在这些学号中在查出选修c05课程的学号。在成绩表中也可以很清晰的看出选修了c04和c05课程的只有060101学号。语句:

select sno from sc where cno = "c05" and sno in(select sno from sc where cno = "c04");

也可以使用连接的方式:连接sno。

select a.sno from sc a join sc b on a.sno = b.sno where a.cno = "c04" and b.cno = "c05";

4.2 查询选修了“高等数学”的学生的学号和姓名

4.2.1 嵌套查询,多表查询(三张表)

select sno 学号,sname 姓名 from s where sno in (
    select sno from sc where cno in (
        select cno from c where cname = "高等数学"
    )
);

从课程表中查出选修了高等数学的课程号。再根据课程号在成绩表查出学号。再利用学号在学生表中查出学号和姓名。

4.2.2 连接三张表

直接在三张表中查询,利用where语句连接三张表,并且课程表c中课程为高等数学。

select s.sno,sname
from s,c,sc
where s.sno=sc.sno and c.cno=sc.cno and cname='高等数学'; 

4.3 查询没有选课的学生的学号和姓名

distinct:去重

在成绩表中给课程号cno去重,查出cno。根据cno在学生表中查出不在这些cno中的学号和姓名。

select sno,sname
from s
where sno not in(select distinct sno from sc);

4.4 查找只有男同学选修的课程的课程号

查询男同学选修的课程的课程号。由于一个同学有多个课程,那么这个课程是有可能被女生选了的。不能保证选到的课程号只有男生选了。

需要在学生表中先查出女生的学号 并在成绩表中根据这个学号选出女生选的课程号。在反查出以外的课程号。

select cno from sc where cno not in(
select cno from sc where sno in(
select sno from s where ssex='女'));

4.5 查询年龄比“吴俊”大的男同学的学号和年龄

查询出年龄吴俊的年龄。在学生表中根据男生和比吴俊的年龄大的学生,的学号和年龄。

select sno,sage from s
where sage>(select sage from s where sname='吴俊') and ssex='男';

4.6 查询选修了"c04"课程的学生中,成绩比”李露“高的学生的学号和成绩

查询出李露的学号

并且学号是李露的,课程号是c04的成绩,(sc表)

根据这个成绩,比这个成绩高的学号和成绩。

select sno,score from sc where cno='c04' and score>(
        select score from sc where sno=(
                select sno from s where sname='李露') and cno='c04');

4.7 查询和“孙晓英”在同一个班级的学生的学号、姓名和所在班级

查出孙晓英的班级,根据班级查出学号和姓名和班级。

select sno,sname,sclass from s
where sclass=(select sclass from s where sname='孙晓英');

4.8 查询学生表中比“19电商1”班所有学生年龄都小的学生的学号和年龄

查出班级是19电商1的年龄,在学生表中年龄比查出的年龄都笑的学号和年龄。

select sno,sage from s
where sage<all(select sage from s where sclass='19电商1');

4.9 查询学生表中比“19电商1”班某个学生年龄小的学生的学号和年龄

这里是满足比查出的年龄小的即可,上一题是比查出的最小的还要小,也就是比查出所用的年龄都小。这里就是满足能够比查出的年龄小的就可以了,使用any。

select sno,sage from s
where sage<any(select sage from s where sclass='19电商1');

4.10 查询选修c04成绩最高分学生的学号和成绩

根据成绩降序排序,desc降序,asc升序,limit取第一个最高分。

select sno,score from sc 
where cno='c04' order by score desc limit 1;

4.11 聚合函数

4.11.1 count计数

select count(sno) 学生人数 from s;

select count(ssex) as 男生人数 from s where ssex='男';

统计有多少人选修了,对学号去重,并计数

select count(distinct sno) as 选课人数 from sc;

4.11.2 去重计数

统计有多少门课被选修了

select count(distinct cno) 被选课程数 from sc;

4.11.3 求和

求学生060101的总分数

select sum(score) as 总分 from sc where sno='060101';

4.11.4 最高分

找出课程c01的最高分。select max(score) as 最高分 from sc where cno='c01';

4.11.5 平均值

select avg(score) as 平均分 from sc where sno='060101';

由于c03课程没有成绩,在取平均数时只用三个值,故266/3为平均数。

---end---

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

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

相关文章

Linux内核——Linux内核体系模式(二)

1 Linux系统的中断机制 Linux内核将中断分为两类&#xff1a;硬件中断和软件中断&#xff08;异常&#xff09;。每个中断是由0-255之间的一个数字进行标识。 中断int0-int31&#xff08;0x00-0x1f&#xff09;作为异常int32-int255由用户自己设定 int32-int47对应与8259A中断…

4PCS点云配准算法实现

4PCS点云配准算法的C实现如下&#xff1a; #include <iostream> #include <pcl/io/pcd_io.h> #include <pcl/point_types.h> #include <pcl/common/common.h> #include <pcl/common/distances.h> #include <pcl/common/transforms.h> #in…

经典案列|淘宝商品数据爬取与分析

商品详情页 API接口测试代码 -- 请求示例 url 默认请求参数已经URL编码处理 curl -i "https://api-服务器.cn/taobao/item_get/?key<您自己的apiKey>&secret<您自己的apiSecret>&num_iid45887133725&is_promotion1" API测试页 商品详情页返…

解析 Ferret-UI:多模态大模型在移动用户界面理解中的应用

移动应用的爆炸性增长&#xff0c;用户界面&#xff08;UI&#xff09;的设计越来越复杂&#xff0c;功能也越来越丰富。但现有的多模态大模型&#xff08;MLLMs&#xff09;在理解用户界面时存在局限&#xff0c;尤其是在处理具有特定分辨率和包含众多小型对象&#xff08;如图…

重生之算法刷题之路之链表初探(三)

算法刷题之路之链表初探&#xff08;三&#xff09; 今天来学习的算法题是leecode2链表相加&#xff0c;是一道简单的入门题&#xff0c;但是原子在做的时候其实是有些抓耳挠腮&#xff0c;看了官解之后才恍然大悟&#xff01; 条件 项目解释 有题目可以知道&#xff0c;我们需…

EAGLE-2:一种高效无损的推测性采样方法,提升LLM的推理速度。

欢迎关注我的公众号&#xff1a;Halo咯咯 01。概述 北京大学的研究人员联合微软研究院、滑铁卢大学以及Vector研究所共同推出了EAGLE-2&#xff0c;这是一种利用上下文感知的动态草图树来增强推测性采样的方法。EAGLE-2在先前的EAGLE方法基础上进行了改进&#xff0c;不仅显著…

运维锅总详解RocketMQ

本文尝试从Apache RocketMQ的简介、主要组件及其作用、3种部署模式、Controller集群模式工作流程、最佳实践等方面对其进行详细分析。希望对您有所帮助&#xff01; 一、Apache RocketMQ 简介 Apache RocketMQ 是一个开源的分布式消息中间件&#xff0c;由阿里巴巴集团开发并…

uniapp微信小程序电子签名

先上效果图&#xff0c;不满意可以直接关闭这页签 新建成单独的组件&#xff0c;然后具体功能引入&#xff0c;具体功能点击签名按钮&#xff0c;把当前功能页面用样式隐藏掉&#xff0c;v-show和v-if也行&#xff0c;然后再把这个组件显示出来。 【签名-撤销】原理是之前绘画时…

JVM与Java体系结构

1.JVM与Java体系结构 1.1. 前言 作为Java工程师的你曾被伤害过吗&#xff1f;你是否也遇到过这些问题&#xff1f; 运行着的线上系统突然卡死&#xff0c;系统无法访问&#xff0c;甚至直接OOM想解决线上JVM GC问题&#xff0c;但却无从下手新项目上线&#xff0c;对各种JVM…

运算放大器重要参数详解

运算放大器是一种用于放大电压并实现信号处理和放大的电子设备。以下是运算放大器的一些重要参数及其详解: 增益(Gain): 定义:增益是运算放大器输出电压与输入电压之比,表示运算放大器在输入信号上的放大倍数。重要性:增益决定了信号的放大程度,是运算放大器的基本功能…

python基础语法 004-2流程控制- for遍历

1 遍历 1.1 什么是遍历&#xff1f; 可以遍历的元素&#xff1a;字符串、列表、元组、字典、集合字符串是可以进行for 循环。&#xff08;容器对象&#xff0c;序列&#xff09;可迭代对象iterable 例子&#xff1a; 1 &#xff09;、for遍历字符串&#xff1a; name xiao…

某安全公司DDoS攻击防御2024年6月报告

引言&#xff1a; 在2024年6月&#xff0c;网络空间的安全挑战汹涌澎湃。分布式拒绝服务&#xff08;DDoS&#xff09;攻击频发&#xff0c;针对云服务、金融科技及在线教育平台的精密打击凸显出当前网络威胁环境的严峻性。 某安全公司作为网络安全防护的中坚力量&#xff0c…

中电金信:金Gien乐道 | 6月热门新闻盘点 回顾这一月的焦点事件

“以检之力 e企守护”——上海市检一分院与中电金信开展联学联建 6月24日&#xff0c;上海市人民检察院第一分院与中电金信数字科技集团股份有限公司联合开展“以检之力 e企守护”联学联建活动。双方共同参观了全国检察机关证券期货犯罪办案基地和重大职务犯罪案件办理&#xf…

【办公类-21-18】20240701 养老护理员初级选择题488,制作PyQt5图形界面GUI

背景需求&#xff1a; 6月16日育婴师高级考完了。运气好&#xff0c;抽到的是”护理患腹泻的幼儿”&#xff0c;“晨检与家长沟通”&#xff0c;“4个月婴儿喂蛋黄”&#xff0c;“21个月食谱”&#xff0c;都是我背过的题目&#xff08;没有抽到感统&#xff09; 于是一放假&…

【吴恩达机器学习-week2】可选实验:特征工程和多项式回归【Feature Engineering and Polynomial Regression】

支持我的工作 &#x1f389; 如果您想看到更详细、排版更精美的该系列文章&#xff0c;请访问&#xff1a;2022吴恩达机器学习Deeplearning.ai课程作业 可选实验&#xff1a;特征工程和多项式回归 目标 在本次实验中&#xff0c;你将&#xff1a;探索特征工程和多项式回归&a…

PTFE铲子聚四氟乙烯物料特氟龙铲粉料铲耐酸碱塑料药铲

四氟铲子主要适用于药厂、药企、医药行业专用&#xff0c;用于粉末状及颗粒物状样品的铲取和搅匀等。因为粉料物料对铲子材质要求无污染、本底值低&#xff0c;所以四氟材质成为选择。 其主要特点有&#xff1a; 1.外观纯白色。 2.耐高低温性&#xff1a;可使用温度-200℃&am…

Django学习第一天

Django安装&#xff1a; pip install Django -i https://mirrors.aliyun.com/pypi/simple/ 在需要创建文件的文件目录下写这个命令 django-admin startproject mysite 注意&#xff1a;C:\Users\Administrator\AppData\Local\Programs\Python\Python311\Scripts已加入环境变…

2024/6/30 英语每日一段

Years of economic and political turbulence have brought stagnation.“In a world where there is more risk and uncertainty, people become reluctant to voluntarily move jobs and find better jobs,” says Manning. At the same time, businesses have cut back on i…

STM32实现串口发送字符和字符串

效果&#xff1a;(字符串的收发还是有问题&#xff0c;只能实现预置字符串的发送&#xff0c;无法实现输入字符串回响) 代码: #include "uart4.h"void hal_uart4_init() {// GPIOB使能RCC->MP_AHB4ENSETR | (0x1 << 1);// GPIOG使能RCC->MP_AHB4ENSETR …

VUE2及其生态查漏补缺

1、数据代理概括 数据代理过程相当于是进行了 vm 代理 vm_data中的属性&#xff0c;vm._data 是与 我们vue文件中写的 data是全等的 //创建Vue实例let data { //data中用于存储数据&#xff0c;数据供el所指定的容器去使用&#xff0c;值我们暂时先写成一个对象。name:atguig…