为了简化MyBatis的使用MyBatis的使用,MyBatis提供了接口方式自动化生成调用过程,可以大大简化MyBatis的开发
开发映射文件:
<select id="queryOne" resultType="cn.tedu.mybatis.beans.User">
select * from user where id = #{id}
</select>
<select id="queryAll" flushCache="true" resultType="Alias_User">
<include refid="saUser"/>
</select>
开发接口:
接口的名字和映射文件的名字相同,接口中方法的名字和要调用的映射文件中的标签的id相同,
方法的参数和被调用的标签中的sql中需要的参数对应
package cn.tedu.mybatis.beans; import java.util.List; public interface UserMapper {
public User queryOne(int id);
public List<User> queryAll();
}
开发测试类:
// 根据配置文件创建sqlSessionFactory
private SqlSessionFactory factory = null;
@Before
public void before() throws Exception{
//1.读取MyBatis核心配置文件
InputStream in = Resources.getResourceAsStream("sqlMapConfig.xml");
//2.根据配置文件创建sqlSessionFactory
factory = new SqlSessionFactoryBuilder().build(in);
} /**
* 通过接口操作MyBatis
*/
@Test
public void test18(){
//1.第一次事务
SqlSession session = factory.openSession();
//2.通过接口获取映射对象
UserMapper usermapper = session.getMapper(UserMapper.class);
//3.通过映射对象调用方法
User user = usermapper.queryOne(1);
List<User> list = usermapper.queryAll();
//4.打印结果
System.out.println(user);
System.out.println(list);
}
真正开发中,都是使用这种接口+配置文件方式,实现MyBatis的使用