最后一個(gè)是正確的,前邊的三個(gè)是可能遇到的坑,給大家展示一下,如果不需要的,可以直接跳到最后看:

有時(shí)候我們需要查詢一張表內(nèi)一段時(shí)間內(nèi)操作的數(shù)據(jù),大家很容易就想到了 between ? and ? 這個(gè) 句型的sql 對(duì)不對(duì)? ,如果現(xiàn)在需要兩個(gè)參數(shù)(比如一個(gè)開始日期,一個(gè)結(jié)束日期)來傳遞,需求是選擇一個(gè)參數(shù)或者兩個(gè)參數(shù)都可以查詢,但是如下邊這個(gè)條件判斷使用and連接,此時(shí)需要兩個(gè)參數(shù)都要有,才會(huì)有查詢結(jié)果,當(dāng)其中有一個(gè)日期參數(shù)為空的時(shí)候,這個(gè)sql就不會(huì)被執(zhí)行,必須要兩個(gè)參數(shù)才可以查詢,這與我們的需求不符合,所以不可取,

 <if test="beginDate != null and beginDate != '' and endDate != null and endDate != ''">
            stock_bill.bill_date between #{beginDate} and #{endDate} </if>

現(xiàn)在我們將其中的兩個(gè)條件之間的and 改為or試一試

 <if test="beginDate != null and beginDate != '' or endDate != null and endDate != ''">
          AND stock_bill.bill_date between #{beginDate} and #{endDate} </if>

此時(shí)如果輸入兩個(gè)日期參數(shù)同樣可以查詢到對(duì)應(yīng)的數(shù)據(jù),但是如果只輸入一個(gè)開始日期參數(shù),此時(shí)查詢結(jié)果為空,通過打印sql,我們可以看到只有一個(gè)開始日期,沒有結(jié)束日期,between ? and ? 的兩個(gè)日期參數(shù)不完整,一個(gè)參數(shù)為空,所以這個(gè)sql 就發(fā)生了錯(cuò)誤,這顯然與我們的初衷不符合,所以這個(gè)方法也不可取,打印sql如下:

seo優(yōu)化培訓(xùn),網(wǎng)絡(luò)推廣培訓(xùn),網(wǎng)絡(luò)營(yíng)銷培訓(xùn),SEM培訓(xùn),網(wǎng)絡(luò)優(yōu)化,在線營(yíng)銷培訓(xùn)

延伸閱讀

學(xué)習(xí)是年輕人改變自己的最好方式-Java培訓(xùn),做最負(fù)責(zé)任的教育,學(xué)習(xí)改變命運(yùn),軟件學(xué)習(xí),再就業(yè),大學(xué)生如何就業(yè),幫大學(xué)生找到好工作,lphotoshop培訓(xùn),電腦培訓(xùn),電腦維修培訓(xùn),移動(dòng)軟件開發(fā)培訓(xùn),網(wǎng)站設(shè)計(jì)培訓(xùn),網(wǎng)站建設(shè)培訓(xùn)學(xué)習(xí)是年輕人改變自己的最好方式