A表中每行对应B表中0-2行,查询结果固定2行,没有的为空
3条回答 默认 最新
关注 你没说数据库类型和版本,我以oracle举例
select a.a,b.b from (select a.*, 1 od from test_table_a a union all select a.*, 2 od from test_table_a a) a left join (select b.*, row_number() over(partition by b.a order by b.b) od from test_table_b b) b on a.a = b.a and a.od = b.od ;
这个开窗函数,有一部分数据库是不支持的。
其实关键点在于,你想得到的记录数是A表的翻倍,但翻倍后,关联条件就不是唯一的,因此要构造一个虚拟的列,让它能和a字段一起定位唯一行。同理,在B表里也要有一个与之相匹配的列,在这里用到了开窗函数产生一个序号本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥100 set_link_state
- ¥15 虚幻5 UE美术毛发渲染
- ¥15 CVRP 图论 物流运输优化
- ¥15 Tableau online 嵌入ppt失败
- ¥100 支付宝网页转账系统不识别账号
- ¥15 基于单片机的靶位控制系统
- ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
- ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
- ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
- ¥15 手机接入宽带网线,如何释放宽带全部速度