巧妙mybatis避免Where 空條件的尷尬
我就廢話(huà)不多說(shuō)了,大家還是直接看代碼吧~
<select resultType='Blog'> SELECT * FROM BLOG WHERE <if test='state != null'> state = #{state} </if> </select>
如果state參數(shù)為空時(shí),最終生成SQL語(yǔ)句為
SELECT * FROM BLOG
WHERE
執(zhí)行會(huì)出錯(cuò),當(dāng)然,你可以在where 后加一個(gè)1=1,改成
<select resultType='Blog'> SELECT * FROM BLOG WHERE 1=1 <if test='state != null'> and state = #{state} </if> </select>
但是這個(gè)做法不太“環(huán)保”(畢竟引入了一個(gè)垃圾條件),其實(shí)只要改成<where>...</where>即可
<select resultType='Blog'> SELECT * FROM BLOG <where> <if test='state != null'> and state = #{state} </if> </where> </select>
補(bǔ)充知識(shí):mybatis @Select注解中當(dāng)參數(shù)為空則不添加該參數(shù)的判斷
如下所示:
@Select('select * from '+DEPTTABLE+' ')
List<Dept> selectAllDept();
在mybatis中不用xml文件的形式,selectDept方法執(zhí)行的就是上面的Sql語(yǔ)句,如果是遇到動(dòng)態(tài)的語(yǔ)句就需要用到下面的形式。
1.用Provider去實(shí)現(xiàn)SQL拼接:
@SelectProvider(type=DeptDynaSqlProvider.class,method='count') Integer count(Map<String, Object> params);//DeptDynaSqlProvider.class 類(lèi)中的方法public String count(Map<String, Object> params){return new SQL(){{SELECT('count(*)');FROM(DEPTTABLE);if(params.get('dept') != null){Dept dept = (Dept) params.get('dept');if(dept.getName() != null && !dept.getName().equals('')){WHERE(' name LIKE CONCAT (’%’,#{dept.name},’%’) ');}}}}.toString();}
2.還有一種方式是用script標(biāo)簽包圍,像xml語(yǔ)法一樣書(shū)寫(xiě)
@Select({'<script>', 'SELECT * FROM tbl_order', 'WHERE 1=1', '<when test=’title!=null’>', 'AND mydate = #{mydate}', '</when>', '</script>'})
注意:方式1有個(gè)隱患就是當(dāng)傳入?yún)?shù)為空的時(shí)候,可能會(huì)造成全表查詢(xún)。
復(fù)雜SQL用方式2會(huì)比較靈活(當(dāng)然,并不建議寫(xiě)復(fù)雜SQL),而且可以抽象成通用的基類(lèi),使每個(gè)DAO都可以通過(guò)這個(gè)基類(lèi)實(shí)現(xiàn)基本的通用查詢(xún),原理類(lèi)似Spring JDBC Template。
以上這篇巧妙mybatis避免Where 空條件的尷尬就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. Windwos下MySQL 64位壓縮包的安裝方法學(xué)習(xí)記錄2. mysql-bin.000001文件的來(lái)源及處理方法3. mysql命令行客戶(hù)端結(jié)果分頁(yè)瀏覽4. Access數(shù)據(jù)庫(kù)安全的幾個(gè)問(wèn)題5. ACCESS轉(zhuǎn)SQL數(shù)據(jù)庫(kù)相關(guān)的幾個(gè)技能6. MySQL中 concat函數(shù)的使用7. MYSQL數(shù)據(jù)庫(kù)存文本轉(zhuǎn)存數(shù)據(jù)庫(kù)問(wèn)題8. mysql啟動(dòng)時(shí)報(bào)錯(cuò) ERROR! Manager of pid-file quit without9. 數(shù)據(jù)庫(kù)相關(guān)的幾個(gè)技能:ACCESS轉(zhuǎn)SQL10. MySQL中InnoDB和MyISAM類(lèi)型的差別

網(wǎng)公網(wǎng)安備