在MyBatis中,可以使用foreach標簽來傳入數組并遍歷。你可以按照以下步驟進行操作:
SELECT * FROM my_table WHERE id IN
<foreach collection="list" item="item" open="(" close=")" separator=",">
#{item}
</foreach>
在這個例子中,list是傳入的數組參數的名稱,item是在循環中使用的每個數組元素的名稱,open指定in語句的開頭,close指定結尾,separator指定分隔符。
<select id="getData" parameterType="java.util.List" resultType="com.example.MyTable">
SELECT * FROM my_table WHERE id IN
<foreach collection="list" item="item" open="(" close=")" separator=",">
#{item}
</foreach>
</select>
在這個例子中,getData是SQL語句的ID,parameterType指定參數類型為java.util.List,resultType指定返回結果的類型為com.example.MyTable。
List<Integer> ids = Arrays.asList(1, 2, 3, 4);
List<MyTable> data = sqlSession.selectList("getData", ids);
在這個例子中,ids是包含要查詢的id的List對象,getData是SQL語句的ID,sqlSession是MyBatis的會話對象,selectList方法用于執行查詢并返回結果。
通過以上步驟,你就可以在MyBatis中傳入數組并遍歷了。