初识MyBatis

引言

Java互联网应用可以通过mybatis框架访问数据库,使用MyBatis框架主要有一下三个优点:

  • 不屏蔽SQL,开发人员可以更为精确地定位SQL语句,可以对其进行优化和改造,有利于互联网系统性能的提高
  • 提供强大灵活的映射机制,提供动态SQL的功能,允许我们根据不同条件组装SQL,可维护性比较高
  • 在MyBatis中,提供了Mapper的接口编程,只要一个XML和一个接口就能创建映射器,进一步简化工作,使开发人员更集中于业务逻辑

准备MyBatis环境

在搭建环境时用的是MyBatis版本为3.4.5(可能无法下载),我把它上传到了百度云盘, 密码: xwaa 方便大家下载.解压缩后会看如下文件目录

MyBatis-3.4.5文件目录

MyBatis核心组件

MyBatis组件有四部分:

  • SqlSessionFactoryBuilder(构造器):它会根据配置或者代码来生成SqlSessionFactory,采用的是分步构建的Builder模式
  • SqlSessionFactory(工厂接口):依靠它来生成SqlSession,使用的是工厂模式
  • SqlSession(会话):既可以发送sql执行返回结果,也可以获取Mapper的接口.在现有的技术中,一般我们会让其在业务逻辑代码中小时,而使用的MyBatis体感那个的SQL Mapper接口编程技术,能提高代码的可读性和可维护性.
  • SQL Mapper:MyBatis新设计的组件,它由一个Java接口和xml文件(或注解)构成,需要给出对应的映射规则.

构建SqlSessionFactory

在Mybatis中既可以通过读取配置的xml文件生成SqlSessionFactory,也可以通过Java代码的形式生成SqlSessionFactory.一般都采用xml的形式
而在MyBatis中,xml分为两类,一类是基础配置文件,一般只有一个,主要是配置一些最基本的上下文参数和运行环境;另一类是映射文件,配置映射关系、SQL、参数等信息。先看一份简易的基础配置文件,代码如下所示:

<!DOCTYPE configuration
        PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
    <!-- 数据库环境配置 -->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC"></transactionManager>
            <!--数据源配置 type=POOLED代表采用的MyBatis内部提供的连接池-->
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver"/>
                <property name="url" value="jdbc:mysql://localhost:3306/blogdemo"/>
                <property name="username"    value="root"/>
                <property name="password" value="mysql123"/>
            </dataSource>
        </environment>
    </environments>
    <!--别名配置-->
    <typeAliases>
        <!-- 为单个类配置别名,Blogger代表ssm.blog.entity.Blogger -->
        <typeAliases alias="Blogger" type="ssm.blog.entity.Blogger">
        <!-- 为实体类包配置别名,整个包中的类都可以用类名作为别名 -->
        <package name="ssm.blog.entity"/>
    </typeAliases>
 <!--映射文件配置-->
    <mappers>
        <package name="com.test.pojo"/>
    </mappers>
</configuration>

有了基础配置文件,就可以用简短的代码生成SqlSessionFactory了,代码如下所示:

public class MyBatisUtil {
    private static SqlSessionFactory sqlSessionFactory;
    static {
        try {
//            使用MyBatis提供的Resources类加载配置文件
            InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
//            构建SqlSession的工厂
            sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    public static SqlSession getSession() {
        return sqlSessionFactory.openSession();
    }
}

首先读取mybatis-config.xml,然后通过SqlSessionFactoryBuilder的Builder方法去创建SqlSessionFactory。

SqlSession

在MyBatis中SqlSession是核心接口。它有两个实现类:一个是DefaultSqlSession,单线程使用;另一个是SqlSessionManager,在多线程环境下使用。SqlSession类似jdbc中的Connection对象,代表着一个资源的启用。主要有以下三个作用:

  • 获取Mapper接口
  • 发送SQL给数据库
  • 控制数据库事务
    它的创建方法也挺简单:
    SqlSession sqlSession=sqlSessionFactory.openSession();
    sqlSession控制数据库事务的方法:
SqlSession sqlsession=null;
try{
  //打开Session会话
  sqlsession=sqlSessionFactory.openSession();
  //some code...
  //提交事务
  sqlsession.commit();
}catch(Exception e){
  sqlsession.rollback;
}finally{
  if(sqlsession!=null){
    //确保资源被顺利关闭
    sqlsession.close();
  }
}
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 198,932评论 5 466
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,554评论 2 375
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 145,894评论 0 328
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,442评论 1 268
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,347评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,899评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,325评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,980评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,196评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,163评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,085评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,826评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,389评论 3 302
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,501评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,753评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,171评论 2 344
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,616评论 2 339

推荐阅读更多精彩内容