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

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

背景:

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

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

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

select a from b join c)

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

 先写select的部分:

SELECT c.id,                      -- 计算记录IDo1.param AS num1,          -- 第一个操作数的值,命名为num1op.operator,               -- 运算符o2.param AS num2,          -- 第二个操作数的值,命名为num2c.result,                  -- 计算结果c.spend_time,              -- 计算耗时c.created_at               -- 创建时间

 from部分:

FROM cal c            -- 从calculations表查询,简称为c

join部分 :

1.关联第一个操作数:

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

2.关联运算符:

JOIN operators op              -- 关联operators表,简称为opON c.id = op.cal_id          -- 通过cal_id关联

 3.关联第二个操作数:

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

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

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没毛病!! 

http://www.lqws.cn/news/151705.html

相关文章:

  • SQL SERVER中获取外部数据的两种方法!
  • Postgresql常用函数操作
  • Flask-SQLAlchemy使用小结
  • AppWeb
  • JavaSec-XSS
  • 如何防止看板任务长期停滞不前
  • Ubuntu中常用的网络命令指南
  • html文字红色粗体,闪烁渐变动画效果
  • 在Spring Boot 3.3中使用Druid数据源及其监控功能
  • 分析vban的utlis中的helper方法(1)——数组
  • Linux-07 ubuntu 的 chrome 启动不了
  • Ubuntu ifconfig 查不到ens33网卡
  • 【Android基础回顾】三:Android启动流程
  • 44、web实验-后台管理系统基本功能
  • CentOS 7 如何pip3安装pyaudio?
  • 【ArcGIS应用】ArcGIS‌应用如何进行影像分类?
  • Eureka REST 相关接口
  • OpenAI技术路线急转:从TypeScript到Rust的Codex CLI重构内幕
  • Java八股文——集合「List篇」
  • 深度学习习题2
  • 10_聚类
  • vlan(虚拟局域网)逻辑图解+实验详解
  • ceph pool 修改故障域
  • 并发编程 - go版
  • android知识总结
  • 深入学习RabbitMQ队列的知识
  • RabbitMQ实用技巧
  • Soundprivacy
  • hbase资源和数据权限控制
  • 通过BUG(prvIdleTask、pxTasksWaitingTerminatio不断跳转问题)了解空闲函数(prvIdleTask)和TCB