Mybatis-数据库查询单元测试步骤详解

@Test
public void queryAllUsers() throws Exception {
    // 读取核心配置文件
    InputStream is = Resources.getResourceAsStream("mybatis-config.xml");
    // 创建工厂,通过将配置文件作为输入流,通过工厂产生sqlSession对象;
    SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
    SqlSession sqlSession = sqlSessionFactory.openSession(true);
    UserMapper userMapper = sqlSession.getMapper(UserMapper.class);
    List<User> userList = userMapper.queryAllUsers();
    for ( User user:userList) {
        System.out.println(user);
    }
    sqlSession.close();
    is.close();
}

以下是每一步的作用说明:

  1. @Test:这是一个JUnit测试注解,表示该方法是一个测试方法。
  2. public void queryAllUsers() throws Exception:这是方法的定义,方法名为queryAllUsers,没有参数,返回类型为void,并且可能抛出异常。
  3. InputStream is = Resources.getResourceAsStream("mybatis-config.xml");:这行代码通过调用Resources.getResourceAsStream方法来获取名为"mybatis-config.xml"的核心配置文件的输入流。这个文件包含了MyBatis的配置信息。
  4. SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);:这行代码创建了一个SqlSessionFactory对象,用于创建和管理SQL会话。它通过调用SqlSessionFactoryBuilder类的build方法并传入配置文件的输入流来实现。
  5. SqlSession sqlSession = sqlSessionFactory.openSession(true);:这行代码打开一个新的SQL会话,并将其赋值给sqlSession变量。第二个参数true表示该会话是自动提交模式,即在执行完SQL语句后会自动提交事务。
  6. UserMapper userMapper = sqlSession.getMapper(UserMapper.class);:这行代码从sqlSession中获取一个UserMapper接口的实现类实例,用于执行与用户相关的数据库操作。
  7. List<User> userList = userMapper.queryAllUsers();:这行代码调用UserMapper接口的queryAllUsers方法来执行查询所有用户的SQL语句,并将结果存储在一个List<User>类型的变量userList中。
  8. for ( User user:userList) { ... }:这是一个循环语句,遍历userList中的每个用户对象,并打印出用户的信息。
  9. sqlSession.close();:这行代码关闭当前的SQL会话。
  10. is.close();:这行代码关闭核心配置文件的输入流。

 

  • 17
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值