MyBatis详解如何实现Dao层接口

网友投稿 956 2022-10-12

MyBatis详解如何实现Dao层接口

MyBatis详解如何实现Dao层接口

目录传统开发方式编写UserDao接口编写UserDaompl实现传统测试方法代理开发方法代理开发方式介绍编写UserMapper接口测试代理方法

传统开发方式

编写UserDao接口

public interface UserMapper {

public List findAll() throws IOException;

}

编写UserDaompl实现

public class UserMapperImp implements UserMapper {

@Override

public List findAll() throws IOException {

InputStream resourceAsStream = Resources.getResourceAsStream("sqlMapConfig.xml");

SqlSessionFactory build = new SqlSessionFactoryBuilder().build(resourceAsStream);

SqlSession sqlSession = build.openSession();

List users=sqlSession.selectList("User.findAll");

sqlSession.close();

return users;

}

}

传统测试方法

public class ServiceCode {

public static void main(String[] args) throws IOException {

UserMapper userMapper = new UserMapperImp();

List all = userMapper.findAll();

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 findAll() ;

}

测试代码:

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 all = mapper.findAll();

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小时内删除侵权内容。

上一篇:为 sublime text 2&3 准备的微信应用号/小程序 snippet(为的拼音)
下一篇:Openlayers示例4 | Animated GIF
相关文章

 发表评论

暂时没有评论,来抢沙发吧~