巧妙mybatis避免Where 空條件的尷尬
我就廢話不多說(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 類中的方法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ǔ)法一樣書寫
@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ì)造成全表查詢。
復(fù)雜SQL用方式2會(huì)比較靈活(當(dāng)然,并不建議寫復(fù)雜SQL),而且可以抽象成通用的基類,使每個(gè)DAO都可以通過(guò)這個(gè)基類實(shí)現(xiàn)基本的通用查詢,原理類似Spring JDBC Template。
以上這篇巧妙mybatis避免Where 空條件的尷尬就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. mysql之如何查找配置文件my.ini的位置2. MySQL高并發(fā)生成唯一訂單號(hào)的方法實(shí)現(xiàn)3. MySQL Binlog 日志處理工具對(duì)比分析4. SQL Server使用CROSS APPLY與OUTER APPLY實(shí)現(xiàn)連接查詢5. SQL Server查詢結(jié)果導(dǎo)出到EXCEL表格的圖文教程6. MySQL多表查詢與7種JOINS的實(shí)現(xiàn)舉例7. MyBatis批量添加數(shù)據(jù)2種實(shí)現(xiàn)方法8. Microsoft Office Access建立有效性規(guī)則的方法9. Mybatis傳入List實(shí)現(xiàn)批量更新的示例代碼10. sqlite時(shí)間戳轉(zhuǎn)時(shí)間語(yǔ)句(時(shí)間轉(zhuǎn)時(shí)間戳)
