不严谨的写法,可能会报错:in (),这种情况不符合mysql的语法。

select from loanwhere LOAN_ID in

#{item}

要么在Mybatis的sql文件中,要么在Java程序中。

sql中的写法:

select *

from p2p_loan_variation where 1= 1

and LOAN_ID in

separator="," close=")">

#{item}

and 1=0

Java中的写法:

List list = null;

if(ListUtils.isNotEmpty(loadIds){

list =loanVariationDao.findByLoanIds(loanIds);

}

return list;

如果有多个Java方法调用dao mapper,在sql中写比较省事,毕竟只需要一次“参数检查”。

上面的写法是针对一个查询条件的,如果有多个查询条件,记得处理条件之间的关系,

比如 a=1 and b =2 or c=3.

如果有in条件,最好加上括号,(a=1) and (b =2 ) or ( c in ...)

041405283617635.gif

其他精彩文章文章

Logo

腾讯云面向开发者汇聚海量精品云计算使用和开发经验,营造开放的云计算技术生态圈。

更多推荐