轻量级前端框架助力开发者提升项目效率与性能
956
2022-10-12
MyBatis详解如何实现Dao层接口
目录传统开发方式编写UserDao接口编写UserDaompl实现传统测试方法代理开发方法代理开发方式介绍编写UserMapper接口测试代理方法
传统开发方式
编写UserDao接口
public interface UserMapper {
public List
}
编写UserDaompl实现
public class UserMapperImp implements UserMapper {
@Override
public List
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
SqlSessionFactory build = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = build.openSession();
List
sqlSession.close();
return users;
}
}
传统测试方法
public class ServiceCode {
public static void main(String[] args) throws IOException {
UserMapper userMapper = new UserMapperImp();
List
System.out.println(all);
}
}
我们发现使用传统的开发方式,每次都要实现接口的代码编写,这样也有很多的代码冗余,也是相当的繁琐,下面,MyBatis为我们提供了代理开发的方法,我们只需要提供接口,MyBatis框架就可以根据接口定义为我们实现。
代理开发方法
代理开发方式介绍
采用MyBatis的代理开发方式实现Dao层的开发,这种方式是我们后面进入企业的主流。
Mapper接口开发方法只需要程序员编写Mapper接口(相当与Dao接口),由MyBatis框架根据接口定义创建接口的动态代理对象,代理对象方法体同上边Dao接口实现类方法。
Mapper接口开发需要遵循一下规范:
1、Mapper.xml文件中的namespace与mapper接口的全限定名相同2、Mapper接口方法名和Mapper.xml中定义的每个Statement的id相同3、Mapper接口方法的输入参数类型和Mapper.xml中定义的每个sql的parameterType的类型相同4、Mapper接口方法的输出参数类型和Mapper.xml中定义的每个sql的resultType的类型相同
编写UserMapper接口
测试代理方法
接口:
public interface UserMapper {
public List
}
测试代码:
public class Test {
public static void main(String[] args) throws Exception {
InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(resourceAsStream);
SqlSession sqlSession = sqlSessionFactory.openSession();
//获得MyBatis框架生产的UserMapper接口的实现类
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
List
for (user user : all) {
System.out.println(user);
}
}
根据id查询:
接口:
public interface UserMapper {
//根据id查询
public User findById(int id);
}
测试:
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user=mapper.findById(2);
System.out.println(user);
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~