MyBatis框架理解与使用

1.半自动化的ORM实现
2.DAO层
3.动态SQL
4.小巧灵活、简单易学
5.持久化是程序数据在瞬时状态和持久状态间转换的过程


MyBatis前身是iBatis,本是Apache的一个开源的项目
官方网站
http://mybatis.org
ORM框架
实体类和SQL语句之间建立映射关系
特点
1.基于SQL语法,简单易学
2.能了解底层封装过程
3.SQL语句封装在配置文件中,便于统一管理与维护,降低程序的耦合度
4.方便程序代码调试

使用MyBatis的开发步骤
1.下载mybatis-3.2.2.jar包并导入工程
2.编写MyBatis核心配置文件(configuration.xml)
3.创建实体类-POJODAO层-SQL映射文件(mapper.xml)

4.创建测试类

-读取核心配置文件mybatis-config.xml
-创建SqlSessionFactory对象,读取配置文件
-创建SqlSession对象
-调用mapper文件进行数据操作
优点
1.与JDBC相比,减少了50%以上的代码量
2.最简单的持久化框架,小巧并简单易学

3.SQL代码从程序代码中彻底分离,可重用
4.提供XML标签,支持编写动态SQL
5.提供映射标签,支持对象与数据库的ORM字段映射
缺点
1.SQL语句编写工作量大,对开发人员有一定要求
2.数据库移植性差
适合
MyBatis专注于SQL本身,是一个足够灵活的DAO层解决方案,适用于性能要求较高或者需求多变的互联网项目


MyBatis的核心对象
SqlSessionFactoryBuilder
SqlSessionFactory
SqlSession
mybatis-config.xml  系统核心配置文件
XXXmapper.xml  SQL映射文件

SqlSessionFactoryBuilder
     1.用过即丢,其生命周期只存在于方法体内
2.可重用其来创建多个 SqlSessionFactory 实例
3.负责构建SqlSessionFactory,并提供多个build方法的重载

build(InputStream inputStream, String environment, Properties properties) 
build(Reader reader, String environment, Properties properties)
build(Configuration config)

配置信息以三种形式提供给SqlSessionFactory的build方法:
InputStream(字节流)、Reader(字符流)、Configuration(类)
读取XML文件构造方式:
String resource = "mybatis-config.xml";   
InputStream is = Resources.getResourceAsStream(resource);   
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
SqlSessionFactory
1.SqlSessionFactory是每个MyBatis应用的核心

2.作用:创建SqlSession实例

SqlSession session = sqlSessionFactory.openSession(boolean autoCommit);
//autoCommittrue:关闭事务控制(默认)
//false:开启事务控制

3.作用域:Application
4.生命周期与应用的生命周期相同
5.单例

-存在于整个应用运行时,并且同时只存在一个对象实例

SqlSession
1.包含了执行SQL所需的所有方法
2.对应一次数据库会话,会话结束必须关闭
3.线程级别,不能共享

实例:

SqlSession session = sqlSessionFactory.openSession();
try {
      // do work
} finally {
     session.close();
}
注意:

-在SqlSession里可以执行多次SQL语句,但一旦关闭了SqlSession就需要重新创建


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值