我是蒻鸡 2022-09-25 16:03 采纳率: 39.1%
浏览 37
已结题

SQLiteSpy环境下跨N个表取数联立输出如何优化实现

img

SQL学的效果一直不是很理想,对于联立、合并等基本操作还是一头雾水。
上面的图片给定的是,最左侧是主数据库,其中过滤出来的ID,作为在后续表中查找的关键,后续更多的表中的ID是不全的,对后续的表格逐个进行查找、联立,如果在规定的条件下,无数据的话,就补零,有数据的话,就补数据,形成最终的输出效果。
但是我只了三张表,假如有更多的表,该怎么写简洁明了,可扩展?
谢谢!

  • 写回答

1条回答 默认 最新

  • _GX_ 2022-09-25 16:37
    关注
    CREATE INDEX idx_id ON B1 (ID);
    
    SELECT
      B1.FL,
      B1.ID,
      B1.DATA1,
      CASE WHEN B2.DATA2 IS NULL THEN 0 ELSE B2.DATA2 END AS DATA2,
      CASE WHEN B3.DATA3 IS NULL THEN 0 ELSE B3.DATA3 END AS DATA3,
      ...
    FROM B1
    LEFT JOIN B2 ON B2.ID=B1.ID
    LEFT JOIN B3 ON B3.ID=B1.ID
    ...
    WHERE (B1.FL="合肥" OR B1.FL="芜湖") AND B1.KJ="总计";
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月3日
  • 已采纳回答 9月25日
  • 创建了问题 9月25日

悬赏问题

  • ¥15 stm32开发clion时遇到的编译问题
  • ¥15 lna设计 源简并电感型共源放大器
  • ¥15 如何用Labview在myRIO上做LCD显示?(语言-开发语言)
  • ¥15 Vue3地图和异步函数使用
  • ¥15 C++ yoloV5改写遇到的问题
  • ¥20 win11修改中文用户名路径
  • ¥15 win2012磁盘空间不足,c盘正常,d盘无法写入
  • ¥15 用土力学知识进行土坡稳定性分析与挡土墙设计
  • ¥70 PlayWright在Java上连接CDP关联本地Chrome启动失败,貌似是Windows端口转发问题
  • ¥15 帮我写一个c++工程