刚刚开始在工作中用到iBatis 在用到in去查询或者删除 我本来是传递一个String的参数,但是总是报以下的错误
上网查询有一下解决方案,本人已验证是可以的。
1、第一种:传入参数仅有数组
<select );
其他信息:
Iterate的属性:
prepend -可被覆盖的SQL语句组成部分,添加在语句的前面(可选)
property -类型为java.util.List的用于遍历的元素(必选)
open -整个遍历内容体开始的字符串,用于定义括号(可选)
close -整个遍历内容体结束的字符串,用于定义括号(可选)
conjunction -每次遍历内容之间的字符串,用于定义AND或OR(可选)
<iterate>遍历类型为java.util.List的元素。
以上引用地址:http://www.blogjava.net/yuhaibo736/archive/2012/02/03/369304.html
在这里还说明一下MyBatis 和 iBatis 用in的情况不是一样的 下面是MyBatis 用in查询的MXL设置
2、上面的那种方法是用id数组来传递参数的,我还找到另一种方法(已测试过),就是通过传递一个ids字符串来批量删除
ids="1,2,3" 参数字符串
<delete id="delete" parameterClass="java.lang.String">
<![CDATA[
delete from table_name where keyid in(#ids#)
]]>
</delete>
3,大于号小于号特殊字符处理
直接在xml 文件中写 < 号会提示错误,而加上 <![CDATA[<=]]> 就不会了