mybatis 自己实现dao

Posted mantishell

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mybatis 自己实现dao相关的知识,希望对你有一定的参考价值。

当我们遵守以下3条时,我们就不需要写dao接口的实现类:

  1. mybatis的映射配置文件必须和dao接口的包结构相同
  2. 映射配置文件的mapper标签namespace属性的取值必须是dao接口的全限定类型
  3. 映射配置文件的操作(select,update),id属性的取值必须是dao接口的方法名

但我们仍然可以自己写dao接口的实现类,来加深理解使用mybatis,当然这不是一定要这么做的。

在xml项目的基础上稍加更改:

1、在dao包下创建impl.UserDaoImpl.java

技术图片
 1 public class UserDaoImpl implements IUserDao {
 2 
 3     private SqlSessionFactory factory;
 4     //由于要用到SqlSessionFactory,所以需要实例化的时候,把参数传递进来
 5     public UserDaoImpl(SqlSessionFactory factory){
 6         this.factory = factory;
 7     }
 8     public List<User> findAll() {
 9         //使用工厂创建SqlSession对象
10         SqlSession session = factory.openSession();
11         //使用session执行查询方法
12         //statement:就是配置文件的namespace+id
13         List<User> users = session.selectList("com.mantishell.dao.IUserDao.findAll");
14         session.close();
15         return users;
16     }
17 }
View Code

2、修改测试代码

技术图片
 1 //1、读取配置
 2         InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
 3         //2、创建SqlSessionFactory工厂
 4         SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();//创建工厂  mybatis使用了构建者模式,构建者模式:把对象的创建细节隐藏,使使用者直接调用方法即可拿到对象。
 5         SqlSessionFactory factory = builder.build(in);//builder就是构建者
 6         //3、使用工厂创建Dao对象
 7         IUserDao userDao = new UserDaoImpl(factory);
 8         //4、使用代理对象执行方法
 9         List<User> users = userDao.findAll();
10         for (User user : users) {
11             System.out.println(user);
12         }
13         //5、释放资源
14         in.close();
View Code

 

以上是关于mybatis 自己实现dao的主要内容,如果未能解决你的问题,请参考以下文章

使用mybatis完成通用dao和通用service

MyBatis高级特性

mybatis之DAO层自动实现接口

MyBatis是如何为Dao接口创建实现类的

MyBatis是如何为Dao接口创建实现类的

MyBatis-03-笔记