开发者社区> 问答> 正文

怎样判断Mybatis传入参数的值

在查询数据时,想通过循环,每次只查询10万条记录。该怎样把循环的参数传入SQL中,并利用MyBatis判断参数,执行相应的SQL

相应的代码:

//循环查询信息
@SuppressWarnings({ "unchecked", "rawtypes" })
public List getLoop(String loopNum) {

return (List)this.getBySqlKey("getLoop",loopNum);

}
XML:

SELECT *, ROWNUM RN from tablename
    <if test = " _parameter=='1'"> WHERE  RN &lt;=100000  and RN &gt;=1</if>
    <if test = " _parameter=='2'"> WHERE  RN &lt;=200000  and RN &gt;=100001 </if>


一开始if中写的是:

WHERE RN <=100000 and RN >=1
WHERE RN <=200000 and RN >=100001
结果报错:
There is no getter for property named 'loopNum' in 'class java.lang.String'。

然后按照 Mybatis中传参报错 链接里的改成_parameter,执行之后报misfired triggers,一直在查询数据,感觉是在查整个库的数据,但是一直执行不出来。

所以想判断传入MyBatis参数的值,应该使用哪种方法,可不可以用when标签?

展开
收起
a123456678 2016-07-04 11:48:08 3199 0
1 条回答
写回答
取消 提交回答
  • screenshot

    2019-07-17 19:50:36
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Java Spring Boot开发实战系列课程【第6讲】:Spring Boot 2.0实战MyBatis与优化(Java面试题) 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载

相关实验场景

更多