MyBatis中主要类介绍
Resources:负责读取主配置文件
InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml");
SqlSessionFactoryBuilder:创建SqlSessionFactory对象
SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();
SqlSessionFactory factory= builder.build(in);
SqlSessionFactory:重量级对象,程序创建一个对象耗时比较长,使用资源比较多,在整个项目中,有一个就够用了
SqlSessionFactory:接口,该接口的实现类:DefaultSqlSessionFactory
SqlSessionFactory作用:获取SqlSession对象,SqlSession session = factory.openSession();
openSession()方法说明:
1、openSession():无参数的,获取的是非自动提交事务的SqlSession对象
2、openSession(boolean autocommit):openSession(true),获取自动提交事务的SqlSession对象
SqlSession:
SqlSession接口:定义了操作数据的方法,例如selectOne(),selectList(),insert(),update(),delete()等等
SqlSession接口的实现类:DefaultSqlSession
使用要求:SqlSession对象不是线程安全的,需要在方法内部使用,在执行sql语句之前,需要openSession()获取SqlSession对象,在执行完sql语句之后,需要关闭它,执行SqlSession的close()方法,这样能保证它的使用是线程安全的。
//1、读取配置文件 InputStream in = Resources.getResourceAsStream("SqlMapConfig.xml"); //2、创建SqlSessionFactory工厂 SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); SqlSessionFactory factory= builder.build(in); //3、使用工厂生产SqlSession对象 SqlSession session = factory.openSession(); //4、使用SqlSession创建Dao接口的代理对象 IUserDao userDao = session.getMapper(IUserDao.class); //5、使用代理对象执行方法 List<User> users = userDao.findAll(); for (User user:users ) { System.out.println(user); } //6、释放资源 session.close(); in.close();