SqlSessionFactory与SqlSession对象介绍

本文介绍了MyBatis中的核心类SqlSessionFactory和SqlSession。Resources用于读取主配置文件,SqlSessionFactoryBuilder创建SqlSessionFactory实例。SqlSessionFactory作为重量级对象,通常在整个项目中仅需一个。它用于打开SqlSession,提供openSession()方法,包括获取非自动提交和自动提交事务的SqlSession。SqlSession接口包含各种数据库操作方法,并且其实现类为DefaultSqlSession。需要注意SqlSession对象不是线程安全的,应在方法内部使用并及时关闭。

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();
SqlSessionFactoryMyBatis框架的核心对象之一。它是一个单例的数据库映射关系经过编译后的内存镜像。通过SqlSessionFactory对象,可以创建SqlSession对象,用于执行SQL语句和操作数据库。 要创建SqlSessionFactory对象,可以通过SqlSessionFactoryBuilder对象来构建。SqlSessionFactoryBuilder可以从XML配置文件或一个预先定制的Configuration对象构建SqlSessionFactory的实例。 每个MyBatis应用程序都以一个SqlSessionFactory对象的实例为核心。SqlSessionFactory是线程安全的,一旦被创建,应该在应用程序的整个生命周期内存在。因此,在应用程序运行期间,不要重复创建多次SqlSessionFactory对象,推荐使用单例模式。 以下是SqlSessionFactory接口的一些方法: - openSession():使用默认设置创建一个SqlSession对象。 - openSession(boolean autoCommit):根据指定的参数创建一个SqlSession对象。 - openSession(Connection connection):根据给定的数据库连接创建一个SqlSession对象。 - openSession(TransactionIsolationLevel level):根据给定的事务隔离级别创建一个SqlSession对象。 - openSession(ExecutorType execType):根据给定的执行器类型创建一个SqlSession对象。 - openSession(ExecutorType execType, boolean autoCommit):根据给定的执行器类型和自动提交参数创建一个SqlSession对象。 - openSession(ExecutorType execType, TransactionIsolationLevel level):根据给定的执行器类型和事务隔离级别创建一个SqlSession对象。 - openSession(ExecutorType execType, Connection connection):根据给定的执行器类型和数据库连接创建一个SqlSession对象。 - getConfiguration():获取配置对象Configuration。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值