MyBatis原理分析之四:自动映射器Mapper的底层实现原理

简单使用

这是一个简单的Mybatis保存对象的例子

@Test
public void testSave() throws Exception {
    //创建sessionFactory对象
    SqlSessionFactory sf = new SqlSessionFactoryBuilder().
            build(Resources.getResourceAsStream("mybatis-config.xml"));
    //获取session对象
    SqlSession session = sf.openSession();
    //创建实体对象
    User user = new User();
    user.setUsername("toby");
    user.setPassword("123");
    user.setAge(23);
    //保存数据到数据库中
    session.insert("com.toby.mybatis.domain.UserMapper.add", user);
    //提交事务,这个是必须要的,否则即使sql发了也保存不到数据库中
    session.commit();
    //关闭资源
    session.close();
}
<mapper namespace="com.toby.mybatis.domain.UserMapper">
    <!--#{}在传入的对象中找对应的属性值-->
    <!--parameterType传入的参数是什么类型-->
    <insert id="add" parameterType="com.toby.mybatis.domain.User">
        INSERT INTO USER (username,password,age) VALUES (#{username},#{password},#{age})
    </insert>
</mapper>

引出主题

但是在实际中,我们都不是这样操作的,我们是通过Mapper接口,调用接口方法,就能实现CRUD操作,那么关键是,这个接口究竟做了什么事,才是我们关心的.

只要把下面这段代码究竟发生了什么事弄明白,就明白,这个Mapper接口究竟做了什么事.

public void testGetObject() throws Exception {
    SqlSession session = MybatisUtil.openSession();

    UserMapper mapper = session.getMapper(UserMapper.class);
    User user = mapper.get(5L);

    System.out.println(user);
    session.close();
}
public interface UserMapper {

    public void add(User user);
    public User get(Long id);
}

看图

但是我认为,一张流程图就能够看明白这期间所发生的事

mapper接口的原理.png

心血来潮再补上一张时序图


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值