sql 传参

传递一位参数

        <!-- 传参一位数 -->
        <!--parameterType 外部传参一个整数 -->
        <!--resultType 结果的类型 -->
        <select id="findOneById" parameterType="integer" resultType="com.imooc.mybatis.entity.GoodsEntity">
            SELECT * FROM t_goods WHERE goods_id = #{value}
        </select>


    public void testFindOne() throws Exception {
        SqlSession sqlSession = null;
        try {
            //获取sql对象
            sqlSession = MybatisUtils.openSession();
            //执行sql
            GoodsEntity good = sqlSession.selectOne("goods.findOneById",739);
            System.out.println(good.getTilte());
            //查看连接状态
            Connection conn = MybatisUtils.getConnection(sqlSession);

        }catch (Exception e){
            throw e;
        }finally {
            MybatisUtils.release(sqlSession);
        }
    }

传参多位参数

        <!--传递多位参数 -->
        <!--parameterType 传递多位参数-->
        <select id="findMoreParam" parameterType="java.util.Map" resultType="com.imooc.mybatis.entity.GoodsEntity">
            SELECT * FROM t_goods
                WHERE current_price
                BETWEEN #{min} AND #{max}
                ORDER BY current_price DESC limit 0,#{limit}
        </select>


    public void testMoreParam() throws Exception {
        SqlSession sqlSession = null;
        try {
            //获取sql对象
            sqlSession = MybatisUtils.openSession();
            //执行sql
            Map para = new HashMap();

            para.put("min",100);
            para.put("max",200);
            para.put("limit",5);

            List<GoodsEntity> list = sqlSession.selectList("goods.findMoreParam",para);
            for (GoodsEntity good:list
                 ) {
                System.out.println(good.getTilte()+"---"+good.getCurrentPrice());
            }
            //查看连接状态
            Connection conn = MybatisUtils.getConnection(sqlSession);

        }catch (Exception e){
            throw e;
        }finally {
            MybatisUtils.release(sqlSession);
        }
    }

Mybatis中parameterType和parameterMap的区别

    parameterMap和resultMap类似,parameterMap通常应用于mapper中有多个参数要传进来时,表示将查询结果集中列值的类型一一映射到java对象属性的类型上,在开发过程中不推荐这种方式。

     一般使用parameterType直接将查询结果列值类型自动对应到java对象属性类型上,不再配置映射关系一一对应。

 

MyBatis报错笔记——Could not find parameter map java.util.List

  解决办法就是将写错的parameterMap改为parameterType就ok了

posted @ 2020-10-16 21:02  python成长中  阅读(634)  评论(0编辑  收藏  举报