MyBatis之三种参数传递

Mapper文件
<!--包名+接口名-->
<mapper namespace="com.lzj.mapper.FlowerMapper2">
       <!--public  Flower    selectOne(int id);-->
       <select id="selectOne" resultType="flower" parameterType="int">
              <!--根据传入参数的下标获得内容-->
              <!--当且仅当只传入一个参数的时候,接受的名字可以任意书写-->
         select  *  from  flower  where  id =#{0}
   </select>
    <!--
       public  Flower  selectOne2(int  id ,String name)
       public  Flower  selectOne2(Flower fl);
    -->
    <select id="selectOne2" resultType="flower" >
         select  *  from  flower   where  id =#{id}  and  name =#{name}
    </select>
    <!--
     public  Flower  selectOne2(int  a ,String b)
     parameterType:可以省略的
     -->
    <select id="selectOne3" resultType="flower" >
        select  * from  flower  where  id =${a}  and  name =${b}
    </select>
</mapper>


测试类
public class TestC {
    public static void main(String[] args) throws Exception {
         //【1】解析mybatis.xml
        InputStream inputStream = Resources.getResourceAsStream("MyBatis.xml");
        //[2]获得session工厂
        SqlSessionFactory factory = new                    SqlSessionFactoryBuilder().build(inputStream);
        //[3]获得session对象
        SqlSession session = factory.openSession();
        //[4]调用方法
        //【A】参数传递一
        Flower flower = session.selectOne("com.lzj.mapper.FlowerMapper2.selectOne", 1);
        //【B】参数传递二
        Flower  fl =new Flower();
        fl.setName("玫瑰花");
        fl.setId(1);
        Flower flower = session.selectOne("com.lzj.mapper.FlowerMapper2.selectOne2", fl);
        //【B】参数传递三
        Map<String,Object>  map =new HashMap<>();
        map.put("a",1);
        map.put("b","'玫瑰花'");
        Flower flower = session.selectOne("com.lzj.mapper.FlowerMapper2.selectOne3", map);
        System.out.println(flower);
        //[5]关闭
        session.close();

    }
}

[注]:#和$的区别
         #{}相当于占位

       ${} 相当于字符串的拼接
       

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值