MyBatis入门四:MyBatis基本使用二:SqlSessionFactory和SqlSession简单演示;

本篇博客的主要内容是:(1)SqlSessionFactory的演示;(2)SqlSession的演示;(3)本篇博客的内容仅仅是演示这两个类的作用,本篇博客的案例,书写形式都不是实际工作中惯用的书写形式,即本篇博客的目的仅仅是让自己对这俩类有个基本了解。(4)本篇博客内容很简单,快速浏览效果更佳。

目录

一.SqlSessionFactory和SqlSession简介

二.演示案例

1.MyBatisTestor:案例代码

2.代码说明:

(1)代码的基本架构

(2)如果某个数据库连接不上,会报PersistenceException(了解这种情况,以后遇到了这种错误,知道解决的方向就行)

(3)注意Resources使用的是哪一个

(4)本案例的创建Connection仅仅出于演示目的

(5)和以前套路一样,创建连接放在try块中,关闭连接放在finally块中


一.SqlSessionFactory和SqlSession简介


二.演示案例

1.MyBatisTestor:案例代码

package com.imooc.mybatis;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test;

import java.io.IOException;
import java.io.Reader;
import java.sql.Connection;

/**
 * JUnit单元测试类
 */
public class MyBatisTestor {
    @Test
    public void testSqlSessionFactory() {
        try {
            // get是获取;Resources代表资源,就是指文本文件;AsReader是按照字符流的方式读取;
            // Resources.getResourceAsReader()方法会默认从当前编译后class文件路径下去加载这个xml文件;
            Reader reader = Resources.getResourceAsReader("mybatis-config.xml");
            // 初始化SqlSessionFactory对象,同时解析mybatis-config.xml文件;
            // SqlSessionFactoryBuilder使用了构造者模式,利用构造者模式初始化SqlSessionFactory对象;
            SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(reader);
            System.out.println("SessionFactory加载成功。");
            SqlSession sqlSession = null;
            try {
                // 创建SqlSession对象;SqlSession对象是专用于数据库交互的;
                sqlSession = sqlSessionFactory.openSession();
                Connection connection = sqlSession.getConnection();
                System.out.println(connection);
            }catch (Exception e){
                e.printStackTrace();
            }finally {
                if (sqlSession != null) {
                    // 如果在mybatis-config.xml中的<dataSource type="POOLED">,代表使用连接池,close则是将连接回收到连接池中;
                    // 如果在mybatis-config.xml中的<dataSource type="UNPOOLED">,代表不使用连接池,close则是调用Connection.close()方法关闭;
                    sqlSession.close();
                }
            }
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

2.代码说明:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值