Mybatis如何使用注解优化代码
entity层代码不变,因为是优化,所以在dao层新增了一个通过id查询用户的功能,现在来演示一下优化前后的代码对比,希望你们喜欢
entity层代码不变,dao层中的UserMapper中添加一个方法
/**
*根据id查询用户
*/
UserfindUserById(intid);
在UserMapper.xml映射文件中添加
select*fromuserwhereid=#{id};
在test层中的test中使用没有优化的代码展示
packagecom.vg.test;
importcom.vg.dao.UserMapper;
importcom.vg.entity.User;
importorg.apache.ibatis.io.Resources;
importorg.apache.ibatis.session.SqlSession;
importorg.apache.ibatis.session.SqlSessionFactory;
importorg.apache.ibatis.session.SqlSessionFactoryBuilder;
importorg.junit.Test;
importjava.io.InputStream;
importjava.util.List;
/**
*测试类
*/
publicclassTestUserMapper{
/**
*测试方法:查询所有学生
*SqlSessionFactoryBuilder=>SqlSessionFactory=>SqlSession:相当于JDBC中的Connection对象,提供了操作数据库的CRUD方法
*/
@Test
publicvoidtestFindAllUsers()throwsException{
//1.通过Resources类,加载sqlMapConfig.xml,得到文件输入流对象
//Resources类作用:专门读取src目录下的资源文件
InputStreamin=Resources.getResourceAsStream("sqlMapConfig.xml");
//2.实例化会话工厂创建类SqlSessionFactoryBuilder
SqlSessionFactoryBuilderbuilder=newSqlSessionFactoryBuilder();
//3.通过会话工厂创建类,读取上面的输入流,得到会话工厂SqlSessionFactory类
SqlSessionFactorysqlSessionFactory=builder.build(in);
//4.使用SqlSessionFactory对象,创建SqlSession对象
//a)它相当于JDBC中的Connection对象,提供了操作数据库的CRUD方法
//b)它提供了一个getMapper()方法,获取接口的实现对象。
SqlSessionsqlSession=sqlSessionFactory.openSession();
//5.获取接口UserMapper实现类对象(代理对象)
UserMapperuserMapper=sqlSession.getMapper(UserMapper.class);
System.out.println("userMapper="+userMapper);
//6.执行数据库的查询操作,输出用户信息
ListuserList=userMapper.findAllUsers();
for(Useruser:userList){
System.out.println(user);
}
//7.关闭会话,释放资源。
sqlSession.close();
}
@Test
publicvoidtestFindUserById()throwsException{
//1.通过Resources类,加载sqlMapConfig.xml,得到文件输入流对象
//Resources类作用:专门读取src目录下的资源文件
InputStreamin=Resources.getResourceAsStream("sqlMapConfig.xml");
//2.实例化会话工厂创建类SqlSessionFactoryBuilder
SqlSessionFactoryBuilderbuilder=newSqlSessionFactoryBuilder();
//3.通过会话工厂创建类,读取上面的输入流,得到会话工厂SqlSessionFactory类
SqlSessionFactorysqlSessionFactory=builder.build(in);
//4.使用SqlSessionFactory对象,创建SqlSession对象
//a)它相当于JDBC中的Connection对象,提供了操作数据库的CRUD方法
//b)它提供了一个getMapper()方法,获取接口的实现对象。
SqlSessionsqlSession=sqlSessionFactory.openSession();
//5.获取接口UserMapper实现类对象(代理对象)
UserMapperuserMapper=sqlSession.getMapper(UserMapper.class);
System.out.println("userMapper="+userMapper);
//6.调用接口的方法根据id查询用户
Useruser=userMapper.findUserById(1);
System.out.println("user="+user);
//7.关闭会话,释放资源。
sqlSession.close();
}
}
你会发现在这俩个方法中有很多相似的代码,每次写都要重新写,关键是还没有啥软用,现在来看看优化之后的代码
packagecom.vg.test;
importcom.vg.dao.UserMapper;
importcom.vg.entity.User;
importorg.apache.ibatis.io.Resources;
importorg.apache.ibatis.session.SqlSession;
importorg.apache.ibatis.session.SqlSessionFactory;
importorg.apache.ibatis.session.SqlSessionFactoryBuilder;
importorg.junit.After;
importorg.junit.Before;
importorg.junit.BeforeClass;
importorg.junit.Test;
importjava.io.IOException;
importjava.io.InputStream;
importjava.util.List;
/**
*测试类
*/
publicclassTestUserMapper{
privatestaticSqlSessionFactorysqlSessionFactory=null;
privateSqlSessionsqlSession=null;
privateUserMapperuserMapper=null;
//该方法在所有测试方法执行之前执行1次
@BeforeClass
publicstaticvoidinit()throwsException{
//1.通过Resources类,加载sqlMapConfig.xml,得到文件输入流对
InputStreamin=Resources.getResourceAsStream("sqlMapConfig.xml");
//2.实例化会话工厂创建类SqlSessionFactoryBuilder对象
SqlSessionFactoryBuilderbuilder=newSqlSessionFactoryBuilder();
//3.根据字节输入流获取SqlSessionFactory对象
sqlSessionFactory=builder.build(in);
}
//该方法会在每个测试方法执行之前执行1次
@Before
publicvoidbefore(){
//4.获取SqlSession对象,等价连接对象
//true:事务自动提交,false:不自动提交,默认值
sqlSession=sqlSessionFactory.openSession();
//5.创建接口实现类对象
userMapper=sqlSession.getMapper(UserMapper.class);
}
/**
*测试方法:查询所有学生
*SqlSessionFactoryBuilder=>SqlSessionFactory=>SqlSession:相当于JDBC中的Connection对象,提供了操作数据库的CRUD方法
*/
@Test
publicvoidtestFindAllUsers()throwsException{
ListuserList=userMapper.findAllUsers();
for(Useruser:userList){
System.out.println(user);
}
}
@Test
publicvoidtestFindUserById()throwsException{
//6.调用接口的方法根据id查询用户
Useruser=userMapper.findUserById(1);
System.out.println("user="+user);
}
@After
publicvoidafter(){
//7.关闭会话,释放资源。
sqlSession.close();
}
}
这样子是不是比以前的代码简单起来了呢?
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。