10-1 sql-sample(超详细逐步解析)

本题目要求编写SQL语句,检索出每个班级中分数最低的同学id,姓名,分数,班级名称a111

表结构:

create table tb_student (
    id int not null primary key,
    name varchar(32)
);
create table tb_score (
    stu_id int,
    score int
);
create table tb_class (
    id int not null,
    name varchar(32)
);
create table tb_student_class
(
    id       int null,
    class_id int null,
    stu_id   int null
);

表样例

tb_student表:

idname
30ddd
49ccc
51aaa
52bbb

tb_score表:

stu_idscore
3099
4979
5180
5259

tb_class表:

idname
1class-1
2class-2
3class-1
4class-2

tb_student_class

idstu_idclass_id
1301
2492
3511
4522

输出样例:

stu_idstu_nameclass_namescore
51aaaclass-180
52bbbclass-259

第一步 : 三表连接找到各班的所有成绩

 

第二步 : 改进第一步语句找到各个班成绩最低的分数

 第三部 : 在第一步的基础上创建包括学生姓名在内的信息全表

 最后一步 : 寻找图3与图二的交集

 

 源代码在这哩~

select b1.stu_id,b1.stu_name,b1.class_name,b1.score
from
(
select a3.stu_id,a4.name as stu_name,a2.name as class_name,score
from tb_score as a1,tb_class as a2,tb_student_class as a3,tb_student as a4
where a1.stu_id = a3.stu_id and a3.class_id = a2.id and a4.id = a3.stu_id
) as b1,
(
select name,min(score) as mins
from tb_score as a1,tb_class as a2,tb_student_class as a3
where a1.stu_id = a3.stu_id and a3.class_id = a2.id
group by name
) as b2
where b1.class_name = b2.name and b1.score = b2.mins

  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在 Mybatis-Plus 中,SQL解析是通过内置的 SQL 解析器来实现的。Mybatis-Plus 使用了 Mybatis 的核心组件和功能,包括 SQL 解析、参数处理、SQL 执行等。 具体的 SQL 解析流程如下: 1. Mybatis-Plus 会通过 `SqlParserUtils` 工具类创建一个 SQL 解析器对象 `SqlParser`。 2. 在执行 SQL 之前,Mybatis-Plus 会调用 `SqlParser` 的 `processSelect` 方法进行解析。该方法会解析 SQL 中的查询字段、表名、条件等信息,并返回一个 `SqlInfo` 对象。 3. `SqlInfo` 对象中包含了解析后的 SQL 语句、参数映射等信息,可以通过该对象获取解析后的 SQL 语句和参数。 4. Mybatis-Plus 将解析后的 SQL 语句和参数传递给 Mybatis 的执行引擎,通过 `SqlSession` 执行 SQL。 需要注意的是,Mybatis-Plus 的 SQL 解析器仅对内置的基本查询方法进行解析,如 `selectById`、`selectList`、`selectPage` 等。对于自定义的 SQL 语句或使用 Mybatis 的 XML 映射文件,则需要手动编写和解析 SQL。 此外,Mybatis-Plus 还提供了一些钩子函数和扩展点,可以自定义 SQL 解析和处理的逻辑。例如,可以实现 `ISqlParser` 接口来自定义 SQL 解析器,实现 `ISqlInjector` 接口来自定义 SQL 注入器等。 总结起来,Mybatis-Plus 是通过内置的 SQL 解析器来解析 SQL,然后将解析后的 SQL 语句和参数传递给 Mybatis 的执行引擎。希望能够解答你的问题!如果还有其他疑问,请继续提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

三块不一样的石头

十分满意,一分打赏~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值