-1
所以我有一个可以被称为下表的情况:查询为1对多表
TABLE A TABLE B TABLE C
ID TOTAL_PRICE ORDER_ID ID ID ORDER ID
1 10 101 101 1001 101
2 20 101 103 1002 101
3 25 103 1003 103
4 10 103 1004 103
所有这些表我很期待这个结果:
EXPECTED OUTPUT
ID TOTAL_PRICE ORDER_ID ID
1 10 101 1001
2 20 101 1002
3 25 103 1003
4 10 103 1004
而且我得到的结果如下:
REAL OUTPUT
ID TOTAL_PRICE ORDER_ID ID
1 10 101 1001
1 10 101 1002
2 20 101 1001
2 20 101 1002
3 25 103 1003
3 25 103 1004
4 10 103 1003
4 10 103 1004
我的SQL如下,我使用SQL甲骨文:
SELECT a.id, a.total_price, a.order.id, c.id
FROM a,b,c
WHERE a.order_id=b.id AND b.id=c.order_id
有了这种情况,我该如何解决问题才能获得预期的输出?谢谢。
请更好地解释您预期的结果背后的逻辑;例如,total_price = 25的记录具有ID为1003和1004(表C)的order_id,那么为什么只需要1003? – Aleksej