最后一個是正確的,前邊的三個是可能遇到的坑,給大家展示一下,如果不需要的,可以直接跳到最后看:
有時候我們需要查詢一張表內(nèi)一段時間內(nèi)操作的數(shù)據(jù),大家很容易就想到了 between ? and ? 這個 句型的sql 對不對? ,如果現(xiàn)在需要兩個參數(shù)(比如一個開始日期,一個結(jié)束日期)來傳遞,需求是選擇一個參數(shù)或者兩個參數(shù)都可以查詢,但是如下邊這個條件判斷使用and連接,此時需要兩個參數(shù)都要有,才會有查詢結(jié)果,當其中有一個日期參數(shù)為空的時候,這個sql就不會被執(zhí)行,必須要兩個參數(shù)才可以查詢,這與我們的需求不符合,所以不可取,
<if test="beginDate != null and beginDate != '' and endDate != null and endDate != ''"> stock_bill.bill_date between #{beginDate} and #{endDate} </if>
現(xiàn)在我們將其中的兩個條件之間的and 改為or試一試
<if test="beginDate != null and beginDate != '' or endDate != null and endDate != ''"> AND stock_bill.bill_date between #{beginDate} and #{endDate} </if>
此時如果輸入兩個日期參數(shù)同樣可以查詢到對應的數(shù)據(jù),但是如果只輸入一個開始日期參數(shù),此時查詢結(jié)果為空,通過打印sql,我們可以看到只有一個開始日期,沒有結(jié)束日期,between ? and ? 的兩個日期參數(shù)不完整,一個參數(shù)為空,所以這個sql 就發(fā)生了錯誤,這顯然與我們的初衷不符合,所以這個方法也不可取,打印sql如下:
延伸閱讀
- ssh框架 2016-09-30
- 阿里移動安全 [無線安全]玩轉(zhuǎn)無線電——不安全的藍牙鎖 2017-07-26
- 消息隊列NetMQ 原理分析4-Socket、Session、Option和Pipe 2024-03-26
- Selective Search for Object Recognition 論文筆記【圖片目標分割】 2017-07-26
- 詞向量-LRWE模型-更好地識別反義詞同義詞 2017-07-26
- 從棧不平衡問題 理解 calling convention 2017-07-26
- php imagemagick 處理 圖片剪切、壓縮、合并、插入文本、背景色透明 2017-07-26
- Swift實現(xiàn)JSON轉(zhuǎn)Model - HandyJSON使用講解 2017-07-26
- 阿里移動安全 Android端惡意鎖屏勒索應用分析 2017-07-26
- 集合結(jié)合數(shù)據(jù)結(jié)構(gòu)來看看(二) 2017-07-26