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