简单使用
这是一个简单的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);
}
看图
但是我认为,一张流程图就能够看明白这期间所发生的事
心血来潮再补上一张时序图