2. SqlSessionFactoryBuilder、sqlSessionFactory、SqlSession类的方法 + 作用域 + 生命周期

使用方法

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 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。
  • 用完之后需要赶紧关闭,否则资源被占用!
    图片
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

你说的白是什么白_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值