(七)mybatis之创建SqlSession

         前文提到了SqlSessionFactory接口,可以用来生产SqlSession。而SqlSession其实也是一个接口类,也就是起到一个门面的角色。那么谁是真正干活的呢?------Executor接口。

         在此处先暂不对Executor深入谈论。在Mybatis中SqlSession接口的实现类有两个:

一个是DefaultSqlSession

 

另一个是SqlSessionManager

 

         我们构建了SqlSessionFactory,然后生成Mybatis的门面接口SqlSession。SqlSession接口类似于一个JDBC中的Connection接口对象,我们需要保证每次用完正常关闭它,所以应该把关闭SqlSession接口的代码写在finally语句中保证每次都会关闭SqlSession,让连接资源归还给数据库。如果我们没有及时关闭资源,数据库的连接资源将很快被耗尽,系统很快因为数据库自愿的匮乏而瘫痪。

//定义SqlSession

SqlSession sqlSession = null;

try{

    //打开SqlSession会话

    sqlSession = sqlSessionFactory.openSession();

    //some code ...

    sqlSession.commit();

}catch(Exception ex){

    System.err.prinltn(ex.getMessage());

    sqlSession.rollback();

}finally{

    //在finally语句中确保资源被顺利关闭

    if(sqlSession!=null){

        sqlSession.close();

    }

}

SqlSession的用途主要有两个:

①    获取映射器,让映射器通过命名空间和方法名称找到对应的SQL,发送给数据库执行后返回结果。

②   直接通过命名信息去执行SQL返回结果。在SqlSession层我们可以通过update、insert、select、delete等方法,带上SQL的id来操作在XML中配置好的SQL;与此同时它也支持事务,通过commit、rollback方法提交或者回滚事务。

(可以打开DefaultSqlSession和SqlSessionManager类来查看,有关于数据操纵的方法)

猜你喜欢

转载自www.cnblogs.com/NYfor2018/p/9101699.html