使用方法
SqlSessionFactoryBuilder
唯一作用就是用来创建SqlSessionFactory
,创建完成之后就不会用到它了,所以SqlSessionFactoryBuiler
生命周期极短。
static SqlSessionFactory sqlSessionFactory = null;
static {
try {
//使用Mybatis第一步 :获取sqlSessionFactory对象
String resource = "mybatis-config.xml";
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
sqlSessionFactory
每个基于 MyBatis 的应用都是以一个 SqlSessionFactory 的实例为核心的。
他通过下面语句,获得 SqlSession 的实例
SqlSession xxxxx = sqlSessionFactory.openSession()
采用封装的方式:
public static SqlSession getSqlSession(){
return sqlSessionFactory.openSession();
}
SqlSession
SqlSession 提供了在数据库执行 SQL 命令所需的所有方法。
比如添加用户:
//增删改需要提交事务,查不用
@Test
public void addUser(){
SqlSession session = MybatisUtils.getSqlSession(); //获取SqlSession连接
UserMapper mapper = session.getMapper(UserMapper.class);
int flag = mapper.addUser(new User(4, "hhhhhh", "1234567"));
if(flag>0) System.out.println("插入成功");
//提交事务
session.commit();
session.close();
}
作用域和生命周期
声明周期和作用域是至关重要的,因为错误的使用会导致非常严重的并发问题。
SqlSessionFactoryBuilder:
- 一旦创建了SqlSessionFactory,就不再需要它了
- 局部变量
SqlSessionFactory:
- 说白了就可以想象为:数据库连接池
- SqlSessionFactory一旦被创建就应该在应用的运行期间一直存在, 没有任何理由丢弃它或重新创建一个实例。
- 因此SqlSessionFactory的最佳作用域是应用作用域(ApplicationContext)。
- 最简单的就是使用 单例模式 或静态单例模式。
SqlSession :
- 连接到连接池的一个请求
- SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。
- 用完之后需要赶紧关闭,否则资源被占用!