Mybatis中如何查詢時間段內的數據


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

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

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

現在我們將其中的兩個條件之間的and 改為or試一試

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

此時如果輸入兩個日期參數同樣可以查詢到對應的數據,但是如果只輸入一個開始日期參數,此時查詢結果為空,通過打印sql,我們可以看到只有一個開始日期,沒有結束日期,between ? and ? 的兩個日期參數不完整,一個參數為空,所以這個sql 就發生了錯誤,這顯然與我們的初衷不符合,所以這個方法也不可取,打印sql如下:

看來想要通過一個參數就可以查詢到對應的數據,使用between?and ?是不行的,我只好放棄了between? and? ,而把他們都拆開來。代碼如下:

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

此時的我又遇到了另外的坑,報錯信息如下

The content of elements must consist of well-formed character data or markup. 這個錯誤是說我的><號不符合xml規范,仔細一想真是,腦子不夠用了,這么簡單地錯誤都出來了,看來真是不能心急,於是把>< 號使用了<![CDATA[ ]]>標簽括起來,代碼如下:

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

ok,然后啟動之后,我只選擇開始時間,只選擇結束時間,同時選擇開始時間和結束時間,發現查詢的結果都是正確的。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM