mybatis开发dao两种方法

2022-07-01 19:15:48 浏览数 (1)

大家好,又见面了,我是你们的朋友全栈君。

mybatis是一个支持普通SQL查询,存储过程和高级映射的优秀的持久层的框架,是apache下的顶级项目。mybatis消除了几乎所有的JDBC代码和参数的手工设置以及对结果集的检索封装。mybatis可以使用简单的XML或注解用于配置和原始映射,将接口和Java的POJO映射成数据库中的记录。

其中,开发dao有两种方法,一种原始的dao开发方法,程序员需要写dao接口和dao实现类。另一种是mapper代理方法,程序员只需要写mapper接口相当于dao接口。

原始dao开发方法

1.编写dao接口(UserDao)

代码语言:javascript复制
public interface UserDao {  
    // 根据id查询用户信息  
    public User findUserById(int id) throws Exception;  
} 

2.编写dao实现类

代码语言:javascript复制
public class UserDaoImpl implements UserDao {  
  
    // 需要向dao实现类中注入SqlSessionFactory  
    // 这里通过构造方法注入  
    private SqlSessionFactory sqlSessionFactory;  
  
    public UserDaoImpl(SqlSessionFactory sqlSessionFactory) {  
        this.sqlSessionFactory = sqlSessionFactory;  
    }  
  
    @Override  
    public User findUserById(int id) throws Exception {  
        SqlSession sqlSession = sqlSessionFactory.openSession();  
          
        //这里的test.findUserById是与下面的映射文件user.xml中的namespace id有关。  
        User user = sqlSession.selectOne("test.findUserById", id);  
  
        // 释放资源  
        sqlSession.close();  
  
        return user;  
  
    }  
}  

3.编写映射文件(user.xml)

代码语言:javascript复制
<mapper namespace="test">  
    <select id="findUserById" parameterType="int" resultType="cn.itcast.mybatis.po.User">  
        SELECT * FROM USER WHERE id=#{value}  
    </select>  
</mapper> 

4.编写测试类

代码语言:javascript复制
public class UserDaoImplTest {  
    private SqlSessionFactory sqlSessionFactory;  
  
    // 此方法是在执行testFindUserById之前执行  
    @Before  
    public void setUp() throws Exception {  
        // 创建sqlSessionFactory  
  
        // mybatis配置文件  
        String resource = "SqlMapConfig.xml";  
        // 得到配置文件流  
        InputStream inputStream = Resources.getResourceAsStream(resource);  
  
        // 创建会话工厂,传入mybatis的配置文件信息  
        sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);  
    }  
  
    @Test  
    public void testUserDaoImpl() throws Exception{  
        // 创建UserDao的对象  
        UserDao userDao = new UserDaoImpl(sqlSessionFactory);  
  
        // 调用UserDao的方法  
        User user = userDao.findUserById(1);  
                  
        System.out.println(user);  
    }  
}  

测试结果:

mapper代理方法

1.编写mapper.java(UserMapper.java相当于java接口)

代码语言:javascript复制
public interface UserMapper {  
    // 根据id查询用户信息  
    public User findUserById(int id) throws Exception;  
} 

2.编写mapper.xml(UserMapper.xml)

代码语言:javascript复制
<mapper namespace="cn.itcast.mybatis.mapper.UserMapper">  
  
    <!--通过id查询用户表的记录 -->  
    <select id="findUserById" parameterType="int" resultType="cn.itcast.mybatis.po.User">  
        SELECT * FROM USER WHERE id=#{value}  
    </select>  
  
</mapper> 

注意:

(1)在mapper.xml中namespace等于mapper接口地址

(2)mapper.java接口中的方法名和mapper.xml中statement的id一致

(3)mapper.java接口中的方法输入参数类型和mapper.xml中statement的parameterType指定的类型一致。

(4)mapper.java接口中的方法返回值类型和mapper.xml中statement的resultType指定的类型一致。

3.编写测试类

代码语言:javascript复制
public class UserMapperTest {  
  
    private SqlSessionFactory sqlSessionFactory;  
  
    // 此方法是在执行testFindUserById之前执行  
    @Before  
    public void setUp() throws Exception {  
        // 创建sqlSessionFactory  
  
        // mybatis配置文件  
        String resource = "SqlMapConfig.xml";  
        // 得到配置文件流  
        InputStream inputStream = Resources.getResourceAsStream(resource);  
  
        // 创建会话工厂,传入mybatis的配置文件信息  
        sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);  
    }  
      
    @Test  
    public void testFindUserById() throws Exception {  
        SqlSession sqlSession=sqlSessionFactory.openSession();  
          
        //创建UserMapper对象,mybatis自动生成mapper代理对象  
        UserMapper userMapper =sqlSession.getMapper(UserMapper.class);  
          
        //调用UserMapper的方法  
        User user=userMapper.findUserById(1);  
          
        System.out.println(user);  
          
        sqlSession.close();  
    }  
  
}  

测试结果:

现在最常用的方法是第二种使用mapper代理的方法,不过第一种也有公司在用所以两种都要知道。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/147232.html原文链接:https://javaforall.cn

0 人点赞