- 先確定數(shù)據(jù)要用到哪些表。
- 將多個(gè)表先通過(guò)笛卡爾積變成一個(gè)表。
- 然后去除不符合邏輯的數(shù)據(jù)(根據(jù)兩個(gè)表的關(guān)系去掉)。
- 最后當(dāng)做是一個(gè)虛擬表一樣來(lái)加上條件即可。
?
注意:列名最好使用表別名來(lái)區(qū)別。
?
?
笛卡爾積
?
?
?
?
Demo:
?
左,右連接,內(nèi),外連接
l???????????? 內(nèi)連接:
要點(diǎn):返回的是所有匹配的記錄。
- 2.???????? select * from a,b where a.x = b.x?????? ?????? ?????? ?????? ?????? ?????? ?????? // //內(nèi)連接
l???????????? 外連接有左連接和右連接兩種。
要點(diǎn):返回的是所有匹配的記錄 外加 每行主表外鍵值為null的一條記錄。輔表所有列為null值。
- select * from a left join b on a.x=b.x order by a.x? //左外連接或稱左連接
- select * from a right join b on a.x=b.x order by a.x? //右外連接或稱右連接
select子句順序
子句 |
說(shuō)明 |
是否必須使用 |
select |
要返回的列或表示式 |
是 |
form |
從中檢索數(shù)據(jù)的表 |
僅在從表選擇數(shù)據(jù)時(shí)使用 |
where |
行級(jí)過(guò)濾 |
否 |
group by |
分組說(shuō)明 |
僅在按組計(jì)算聚集時(shí)使用 |
having |
組級(jí)過(guò)濾 |
否 |
order by |
輸出排序順序 |
否 |
limit |
要檢索的行數(shù) |
否 |
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫(xiě)作最大的動(dòng)力,如果您喜歡我的文章,感覺(jué)我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
