如何在mysql中使用left join添加where條件?相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。
創(chuàng)新互聯(lián)建站公司2013年成立,先為翁牛特等服務(wù)建站,翁牛特等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為翁牛特企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問(wèn)題。有g(shù)roup和factor兩張表,一個(gè)group對(duì)應(yīng)多個(gè)factor,現(xiàn)在想查詢有效的group和對(duì)應(yīng)的有效的factor,兩個(gè)表都有isDel邏輯刪除標(biāo)志。
SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id where g.isDel=0 and f.isDel=0
LEFT JOIN 關(guān)鍵字會(huì)從左表 (table_name1) 那里返回所有的行,即使在右表 (table_name2) 中沒(méi)有匹配的行。
上邊這樣寫左邊表要是在右邊表沒(méi)有對(duì)應(yīng)數(shù)據(jù)是查詢不出來(lái)的,原因就是f.isDel=0
這個(gè)代碼問(wèn)題。
SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id and g.isDel=0 and f.isDel=0
這種寫法g.isDel=0
是不會(huì)生效的,導(dǎo)致查詢數(shù)據(jù)根本不對(duì)。
left join中關(guān)于where和on條件的幾個(gè)知識(shí)點(diǎn):
多表left join是會(huì)生成一張臨時(shí)表,并返回給用戶
where條件是針對(duì)最后生成的這張臨時(shí)表進(jìn)行過(guò)濾,過(guò)濾掉不符合where條件的記錄
on條件是對(duì)left join的右表進(jìn)行條件過(guò)濾,但依然返回左表的所有行,右表中沒(méi)有的補(bǔ)為NULL
on條件中如果有對(duì)左表的限制條件,無(wú)論條件真假,依然返回左表的所有行,但是會(huì)影響右表的匹配值。也就是說(shuō)on中左表的限制條件只影響右表的匹配內(nèi)容,不影響返回行數(shù)。
SELECT g.*,f.* FROM groups g LEFT JOIN factor f ON f.groupId = g.id and f.isDel=0 where g.isDel=0
1.對(duì)左表添加條件限制需在where條件中添加,不能放到on后面
2.對(duì)右表添加條件限制需放到on后面,在where條件中添加會(huì)有數(shù)據(jù)行數(shù)差異出現(xiàn)問(wèn)題。
看完上述內(nèi)容,你們掌握如何在mysql中使用left join添加where條件的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!
本文名稱:如何在mysql中使用leftjoin添加where條件-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)地址:http://vcdvsql.cn/article14/cdjdge.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、微信公眾號(hào)、定制網(wǎng)站、商城網(wǎng)站、營(yíng)銷型網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容