您的位置:首页 > 其它

MyBatis框架理解与使用

2017-10-06 22:13 197 查看
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就需要重新创建
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: