参数是map的foreach要怎么写?

来源:4-2 动态 SQL 拼接(下)

未卜先知

2018-07-19 19:46

不能直接遍历map么?

我看了下网上的,只能使用嵌套的方式

声明一个value为map的map,然后在foreach的时候

collection="key"

比如

    public static void main(String[] args) {
        MybatisDao dao = new MybatisDao();
      Map<String,Map<String,Integer>> map = new HashMap<>();
        Map<String,Integer> map1 = new HashMap<>();
        map1.put("aaa",1);
        map1.put("bbb",2);
        map.put("first",map1);
        List<Message> lis = dao.queryMessageByMap(map);
    }

    public List<Message> queryMessageByMap(Map<String,Map<String,Integer>> params){
        DBAccess dbAccess = new DBAccess();
        SqlSession sqlSession = null;
        List<Message> messageList = null;
        try {
            sqlSession = dbAccess.getSqlSession();
            messageList = sqlSession.selectList("Message.selectMap",params);
        } catch (IOException e) {
            e.printStackTrace();
        }
        return messageList;
    }
对应的mapper中的sql:
<select id="selectMap" parameterType="map" resultType="com.imooc.bean.Message">
    select ID,COMMAND,DESCRIPTION,CONTENT from message WHERE id IN
        <foreach collection="first" index="index" item="value" open="(" close=")" separator=",">
            #{value}
        </foreach>
</select>

有能直接就遍历的方法么?

写回答 关注

1回答

  • qq_善思者障_0
    2018-07-31 11:47:21
               #{index.id}


通过自动回复机器人学Mybatis---基础版

微信公众号自动回复功能学习Mybatis,基础教程加案例实战方式学习

107417 学习 · 831 问题

查看课程

相似问题