当前位置: 首页 > news >正文

MySQL多表连接查询3

目录

表结构

创建表

表数据

查询需求:

1.查询student表的所有记录

2.查询student表的第2条到4条记录

3.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息

4.从student表中查询计算机系和英语系的学生的信息

5.从student表中查询年龄18~22岁的学生信息

6.从student表中查询每个院系有多少人

7.从score表中查询每个科目的最高分

8.查询李四的考试科目(c_name)和考试成绩(grade)

9.用连接的方式查询所有学生的信息和考试信息

​10.计算每个学生的总成绩

11.计算每个考试科目的平均成绩

​12.查询计算机成绩低于95的学生信息

​13.查询同时参加计算机和英语考试的学生的信息

14.将计算机考试成绩按从高到低进行排序

15.从student表和score表中查询出学生的学号,然后合并查询结果

16.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩

​17.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩


表结构

        student

        score

创建表

插入语句:

create table student(
    -> id int(10) not null unique primary key,
    -> name varchar(20) not null,
    -> sex varchar(4),
    -> birth year,
    -> department varchar(20),
    -> address varchar(50)
    -> );

create table score(
    -> id int(10) not null unique primary key auto_increment,
    -> stu_id int(10) not null,
    -> c_name varchar(20),
    -> grade int(10)
    -> );

表数据

插入语句:

向student表插入记录的INSERT语句如下:

INSERT INTO student VALUES( 901,'张老大', '男',1985,'计算机系', '北京市海淀区');
INSERT INTO student VALUES( 902,'张老二', '男',1986,'中文系', '北京市昌平区');
INSERT INTO student VALUES( 903,'张三', '女',1990,'中文系', '湖南省永州市');
INSERT INTO student VALUES( 904,'李四', '男',1990,'英语系', '辽宁省阜新市');
INSERT INTO student VALUES( 905,'王五', '女',1991,'英语系', '福建省厦门市');
INSERT INTO student VALUES( 906,'王六', '男',1988,'计算机系', '湖南省衡阳市');

向score表插入记录的INSERT语句如下:

INSERT INTO score VALUES(NULL,901, '计算机',98);
INSERT INTO score VALUES(NULL,901, '英语', 80);
INSERT INTO score VALUES(NULL,902, '计算机',65);
INSERT INTO score VALUES(NULL,902, '中文',88);
INSERT INTO score VALUES(NULL,903, '中文',95);
INSERT INTO score VALUES(NULL,904, '计算机',70);
INSERT INTO score VALUES(NULL,904, '英语',92);
INSERT INTO score VALUES(NULL,905, '英语',94);
INSERT INTO score VALUES(NULL,906, '计算机',90);
INSERT INTO score VALUES(NULL,906, '英语',85);

查询需求:

1.查询student表的所有记录

select *from student;

 

2.查询student表的第2条到4条记录

select *from student limit 1,3;

 

3.从student表查询所有学生的学号(id)、姓名(name)和院系(department)的信息

select id,name,department from student;

 

 

4.从student表中查询计算机系和英语系的学生的信息

select *from student where department in ('中文系','计算机系');

 

5.从student表中查询年龄18~22岁的学生信息

假定当时记录时的年份为2010年

select *,(2010-student.birth) as age from student inner join score on score.stu_id=student.id where (2010-student.birth) between 18 and 22;

 

 

6.从student表中查询每个院系有多少人

select department,count(*) from student group by department;

 

7.从score表中查询每个科目的最高分

select c_name,max(grade) from score group by c_name;

 

8.查询李四的考试科目(c_name)和考试成绩(grade)

select c_name,grade from score inner join student on score.stu_id=student.id where student.name='李四';


9.用连接的方式查询所有学生的信息和考试信息

select *from score inner join student on score.stu_id=student.id;


10.计算每个学生的总成绩

select name,sum(grade) from student inner join score on score.stu_id=student.id group by score.stu_id;


11.计算每个考试科目的平均成绩

select c_name,avg(grade) from student inner join score on score.stu_id=student.id group by score.c_name;


12.查询计算机成绩低于95的学生信息

 select *from student inner join score on score.stu_id=student.id where score.c_name='计算机' and score.grade<95;


13.查询同时参加计算机和英语考试的学生的信息

select *from student where id in(select stu_id from score where c_name='英语' and stu_id in(select stu_id from score where c_name='计算机'));


14.将计算机考试成绩按从高到低进行排序

 select *from student inner join score on student.id=score.stu_id where score.c_name='计算机' order by score.grade desc;


15.从student表和score表中查询出学生的学号,然后合并查询结果

select distinct student.id,student.name from student inner join score on student.id=score.stu_id;


16.查询姓张或者姓王的同学的姓名、院系和考试科目及成绩

select name,department,c_name,grade from student inner join score on student.id=score.stu_id where student.name regexp '^[张|王]';


17.查询都是湖南的学生的姓名、年龄、院系和考试科目及成绩

假定当时记录时的年份为2010年

select name,(2010-birth) as age, department,c_name,grade from student inner join score on student.id=score.stu_id where left(student.address,2)='湖南';

 

http://www.lryc.cn/news/119863.html

相关文章:

  • 【从零开始学习JAVA | 第四十五篇】反射
  • 顺丰科技数据治理实践
  • Nginx+Tomcat负载均衡、动静分离实例详细部署
  • Java多线程(3)---锁策略、CAS和JUC
  • Linux:Shell编辑之文本处理器(awk)
  • 探索FSM (有限状态机)应用
  • 6.continue break
  • 如何在Linux中强制关闭卡住的PyCharm
  • c# Excel数据的导出与导入
  • Kotlin~Mediator中介者模式
  • 石子合并问题
  • 剑指Offer-搜索与回溯算法
  • 【云原生】Docker 详解(三):Docker 镜像管理基础
  • SD-MTSP:蜘蛛蜂优化算法SWO求解单仓库多旅行商问题MATLAB(可更改数据集,旅行商的数量和起点)
  • 【ARM 嵌入式 编译系列 3.1 -- GCC __attribute__((used)) 使用】
  • C++ ModBUS TCP客户端工具 qModMaster 介绍及使用
  • 笔记本电脑如何把sd卡数据恢复
  • 【2023 华数杯全国大学生数学建模竞赛】 B题 不透明制品最优配色方案设计 39页论文及python代码
  • Exams/ece241 2013 q4
  • Android OkHttp源码分析--分发器
  • 大数据面试题:说下Spark中的Transform和Action,为什么Spark要把操作分为Transform和Action?
  • 【图像去噪的扩散滤波】基于线性扩散滤波、边缘增强线性和非线性各向异性滤波的图像去噪研究(Matlab代码实现)
  • python函数、运算符等简单介绍2(无顺序)
  • k8s 自身原理 3
  • SpringBoot 3自带的 HTTP 客户端工具
  • Spring Boot多级缓存实现方案
  • 机器学习笔记:李宏毅chatgpt 大模型 大资料
  • 2023年中国智慧公安行业发展现况及发展趋势分析:数据化建设的覆盖范围不断扩大[图]
  • Apache Dubbo概述
  • React UI组件库