mysql - oracle 多表查詢問題-笛卡兒積過濾
問題描述
問題如下:
查詢出現笛卡兒積過濾的問題 例子: A B C D E Q表
select e.name, e.age, e.phone, q.something from a a, b b, c c, d d, e e, q q where a.id = ’zhejiushiyige id’ and b.id = a.bid and c.id = b.cid and d.id = c.did and e.id = d.eid and q.aid = a.id
就是表e是從a開始一級一級比較下來的,最終得到的e的結果是正確的,但是q的結果會出現兩次,并且q只跟a有關聯,請問怎么查詢才能解決這個問題呢?
問題解答
回答1:q表和a表是一對多的關系,如果q表的結果只想出一條,可以在關聯前先把q表按照aid字段進行匯總,保證每個aid只有一條,如:
select e.name, e.age, e.phone, q.something from a a, b b, c c, d d, e e, (select aid, max(something)) from q group by aid) table_q where a.id = ’zhejiushiyige id’ and b.id = a.bid and c.id = b.cid and d.id = c.did and e.id = d.eid and table_q.aid = a.id
相關文章:
1. html - 哪些情況下float會失效?2. mac連接阿里云docker集群,已經卡了2天了,求問?3. 就一臺服務器,mysql數據庫想實現自動備份,如何設計?4. css3 - text-overflow為何會在li的子標簽a下失效5. javascript - node.js不同模塊之間如何傳值6. android - 哪位大神知道java后臺的api接口的對象傳到前端后輸入日期報錯,是什么情況?求大神指點7. javascript - js控制元素樣式的疑惑8. [前端求職必看]前端開發面試題與答案精選_擴展問題9. docker Toolbox在win10 家庭版中打開報錯10. javascript - 求解答,koa-bodyparser獲取到的參數是空對象,為什么?????
