三表查询SQL怎么写?----小白初学+案例引入

背景:

接上一篇的数据库三范式设计数据库三范式设计---小白初学+案例引入-CSDN博客

为了从我们设计的三张表中联合获取完整的计算历史记录,我们来写下对应的SQL查询语句!

首先确认整体的查询语句结构:

select a from b join c)

sql 复制代码
SELECT [要选择的字段]
FROM [主表]
JOIN [关联表1] ON [关联条件]
JOIN [关联表2] ON [关联条件]
JOIN [关联表3] ON [关联条件]
ORDER BY [排序字段]
LIMIT [返回条数]

先写select的部分:

sql 复制代码
SELECT 
    c.id,                      -- 计算记录ID
    o1.param AS num1,          -- 第一个操作数的值,命名为num1
    op.operator,               -- 运算符
    o2.param AS num2,          -- 第二个操作数的值,命名为num2
    c.result,                  -- 计算结果
    c.spend_time,              -- 计算耗时
    c.created_at               -- 创建时间

from部分:

sql 复制代码
FROM cal c            -- 从calculations表查询,简称为c

join部分 :

1.关联第一个操作数:

sql 复制代码
JOIN operands o1               -- 关联operands表,简称为o1
  ON c.id = o1.cal_id          -- 通过cal_id关联
  AND o1.position = 1          -- 只取position=1的记录(第一个操作数)

2.关联运算符:

sql 复制代码
JOIN operators op              -- 关联operators表,简称为op
  ON c.id = op.cal_id          -- 通过cal_id关联

3.关联第二个操作数:

sql 复制代码
JOIN operands o2               -- 再次关联operands表,简称为o2
  ON c.id = o2.cal_id          -- 通过cal_id关联
  AND o2.position = 2          -- 只取position=2的记录(第二个操作数)

4.最后的排序和限制部分:

sql 复制代码
ORDER BY c.created_at DESC     -- 按创建时间降序排列(最新记录在前)
LIMIT ?                        -- 限制返回条数(参数化查询)

为什么需要这样设计?

  1. 数据关联:通过calculation_id将三张表的记录关联起来

  2. 操作数定位:使用position=1/2区分第一个和第二个操作数

  3. 结果整合:将分散存储的数据重新组合成完整的计算记录


实际效果:

第一步:cal表:比如我们就看这个id=38的,可以知道其耗时10ms,结果是22

第二步:operands表:找到前面说的38,对应的两个操作数是66和3

第三步:operators表:也是找到38,运算符号是除号

最后:总结可以知道 ,66/3=22没毛病!!

相关推荐
科技小花6 小时前
全球化深水区,数据治理成为企业出海 “核心竞争力”
大数据·数据库·人工智能·数据治理·数据中台·全球化
X56617 小时前
如何在 Laravel 中正确保存嵌套动态表单数据(主服务与子服务)
jvm·数据库·python
虹科网络安全8 小时前
艾体宝干货|数据复制详解:类型、原理与适用场景
java·开发语言·数据库
2301_771717218 小时前
解决mysql报错:1406, Data too long for column
android·数据库·mysql
小江的记录本9 小时前
【Kafka核心】架构模型:Producer、Broker、Consumer、Consumer Group、Topic、Partition、Replica
java·数据库·分布式·后端·搜索引擎·架构·kafka
dvjr cloi9 小时前
MySQL Workbench菜单汉化为中文
android·数据库·mysql
dFObBIMmai9 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw09 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl2002092510 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql
ACP广源盛1392462567310 小时前
IX8024与科学大模型的碰撞@ACP#筑牢科研 AI 算力高速枢纽分享
运维·服务器·网络·数据库·人工智能·嵌入式硬件·电脑