MyBatis是一款优秀的基于Java的持久性框架

Mybatis曾经是apache的一个开源项目ibatis,2010年迁移到google,并更名为MyBatis。2013年又迁移到Github。

1.下载MyBatis

​ Github链接:https://github.com/mybatis,打开出现一只奋斗的小肥鸟就对了。

​ 点击MyBatis3。

​ 然后点击下载。

选择你相应的框架版本再对应电脑系统进行下载

2.目录结构介绍

3.MyBatis工作原理

4.在项目中创建XML文件

​ 创建映射文件在dao层:mapper.xml

​ 创建主配置文件在src根目录:mybatis.xml

mapper.xml:

1
2
3
4
5
6
7
8
9
10
11
12
13
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">

<mapper namespace="insert"><!-- namespace命名范围 -->
<!-- 新增:insert,删除:delete,修改:update,查询:select -->
<insert id="insertStudent" parameterType="Student"> <!-- parameterType属性可以省略 -->

INSERT INTO student(stuName,stuAge)VALUES(#{stuName},#{stuAge})<!-- SQL语句 #为占位符 -->

</insert>
</mapper>

mybatis.xml

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">

<!-- xml配置根节点 -->
<configuration>

<!-- 引入properties数据库连接配置 -->
<properties resource="db.properties"/>

<!-- 定义别名 -->
<typeAliases>
<!-- 将指定包中所有类的简单类当做其别名 -->
<package name="cn.chenghao.entity"/>
</typeAliases>

<!-- 定义数据源 -->
<environments default="development"><!-- default写上一个执行环境的id -->
<environment id="development"><!-- 见名知意的id -->
<transactionManager type="JDBC"/><!-- 事务管理器 -->
<dataSource type="POOLED"><!-- 数据库连接池 -->
<property name="driver" value="${driver}"/> <!-- 加载驱动 -->
<property name="url" value="${url}"/> <!-- 建立连接 -->
<property name="username" value="${username}"/> <!-- 数据库用户名 -->
<property name="password" value="${password}"/> <!-- 数据库密码 -->
</dataSource>
</environment>
</environments>

<!-- 注册映射文件 -->
<mappers>
<package name="cn.chenghao.mapper"/><!-- 扫描包下面的映射文件 -->
</mappers>

</configuration>

db.properties

1
2
3
4
driver=com.mysql.jdbc.Driver
url=jdbc:mysql:///EmployDB?useUnicode=true&characterEncoding=utf-8
username=root
password=root

5.MyBatis生命周期

​ 所谓的生命周期就是第一个对象应该存活的时间,比如一些对象一次用完后就要关闭,使它们被Java虚拟机(JVM)销毁,以避免继续占用资源,所以我们会根据每一个组件的作用去确定其生命。

​ (1)SqlSessionFactoryBuilder

   SqlSessionFactoryBuilder的作用就是在于创建SqlSessionFactory,创建成功后,SqlSessionFactoryBuilder就失去了作用,所以它只能存在于创建SqlSessionFactory的方法中,而不要让其长期存在。

​ (2)SqlSessionFactory

   SqlSessionFactory可以被认为是一个数据库连接池,它的作用是创建SqlSession接口对象。因为MyBatis的本质就是Java对数据库的操作,所以SqlSessionFactory的生命周期在于于整个MyBatis的应用之中,所以一旦创建了SqlSessionFactory的生命周期就等同于MyBatis的应用周期。

   由于SqlSessionFactory是一个对数据库的连接池,所以它占据着数据库的连接资源。如果创建多个SqlSessionFactory,那么就存在多个数据库连接池,这样不利于对数据资源的控制,也会导致连接资源被消耗光,出现系统宕机等情况,所以尽量避免发生这样的情况。因此在一般的应用中我们往往希望SqlSessionfactory作为一个单例,让它在应用中补共享。

​ (3)SqlSession

   如果说SqlSessionFactory相当于数据库连接池,那么SqlSession就相当于一个数据库连接(Connection对象),你可以在一个事务里面执行多条SQL,然后通过它的commit、rollback等方法,提交或者回滚事务。所以它应该存活在一个业务请求中,处理完整个请求后,应该关闭这条连接,让它归还给SqlSessionFactory,否则数据库资源就很快被消耗精光,系统应付瘫痪,所以用try…catch…fanally语句来保证其正确关闭。

​ (4)Mapper

   Mapper是一个接口,它由SqlSession所创建,所以它的最大生命周期至多和SqlSession保持一致,尽管它很好用,但是由于SqlSession关闭,它的数据库连接资源也会消失,所以它的生命周期应该小于等于SqlSession的生命周期。Mapper代表是一个请求中的业务处理,所以它应该在一个请求中,一旦处理完了相关的业务,就应该废弃它。

相关文章
评论
分享
  • Nginx学习

    1.什么是Nginx?​ Nginx是一款高性能的HTTP和反向代理轻量级的Web服务器,特点是占有内存少,并发能力强 ​ ·1.正向/反向代理: ​ 正向代理:其实就是类似于VPN,通过代理...

    Nginx学习
  • ZXing生成二维码

    1.什么是二维码?​ (百度百科):二维码又称二维条码,常见的二维码为QR Code,QR全称Quick Response,是一个近几年来移动设备上超流行的一种编码方式,它比传统的Bar Code条形码能存更多的信息,也能表示更...

    ZXing生成二维码
  • Docker学习

    1.什么是Docker?​ Docker是一个开源的应用容器引擎,基于Go语言,遵从Apache2.0协议开源。 ​ Docker支持将软件编译成一个镜像;然后在镜像中各种软件做好配置,将镜像发布出去,其他使用者可以直接使...

    Docker学习
  • Redis学习

    什么是Redis?Redis是一个高性能的(key/value)分布式内存数据库,基于内存运行并支持持久化NoSQL数据库。为什么需要使用Redis?就拿微博说个实例吧:大家都知道使用微博的人可以用亿来进行统计;假如有一天一位明星在微...

    Redis学习
  • 美女壁纸合集

    一、运动系清纯美少女 二、极品性感美女 三、娇俏性感美女 四、短发美少女 五、可爱性感女生

    美女壁纸合集