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

img

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

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="总计";