首页
学习
活动
专区
工具
TVP
发布

优秀的持久层框架-Mybatis框架解析

Topic

Mybatis步骤

mybatis解决原生态jdbc的问题

数据库连接,使用时连接,不使用时释放,对数据库进行频繁连接的开启和关闭,造成数据库资源浪费,影响数据库性能

设想:使用数据库连接池管理数据库连接

将sql语句硬编码到Java代码中,如果sql语句修改,需要重新编译Java代码,不利于系统维护.

设想:将SQL语句配置在xml配置文件中,即使SQL变化,不需要对Java代码进行重新编译

向preparedStatement中设置参数,对占位符位置和设置参数硬编码到Java代码中,不利于系统维护.

设想:将SQL语句及占位符和参数全部配置在xml中

从resultset中遍历结果集数据时,存在硬编码,将获取表的字段进行硬编码,不利于系统维护.

设想:将查询结果集,自动映射成Java对象

持久层框架

Mybatis是一个持久层的框架,让程序将主要精力放在SQL上,通过mybatis提供的映射方式,自由灵活生成满足的SQL语句;可以将preparedStatement中的输入参数自行自动输入映射,将查询结果集灵活映射成Java对象(输出映射)

Mybatis架构

sqlSessionFactoryBuilder

通过sqlSessionFactoryBuilder创建会话工厂sqlSessionFactory

将sqlSessionFactoryBuilder当成一个工具类使用,不需要使用单例模式管理,在需要sqlSessionFactory时,只需要new一次sqlSessionFactoryBuilder就行了

sqlSessionFactory

通过sqlSessionFactory创建sqlSession,使用单例模式管理sqlSessionFactory

sqlSession

sqlSession是一个面向用户的接口, sqlSession中提供很多操作数据库的方法,如:selectOne(),selectList().sqlSession是线程不安全的,在sqlSession实现类中除了有接口中的方法(操作数据库的方法)还有数据域属性.

sqlSession最佳应用场合在方法体内,定义成局部变量使用.

原始Dao开发方法

MybatisDemo02

编写dao,dao.impl,mapper.xml

Test:

public class BookDaoTest {

private SqlSessionFactory sqlSessionFactory;

@Before

public void setUp() throws IOException{

String resource="mybatis-config.xml";

InputStream inputStream=Resources.getResourceAsStream(resource);

sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);

}

@Test

public void testLoadById() throws Exception{

//创建Dao对象

IBookDao bookDao=new BookDao(sqlSessionFactory);

Book book=bookDao.loadById(5);

System.out.println(book);

}

Mapper代理

编写dao,mapper.xml

遵守一定的开发规范:

在mapper.xml中的namespace等于dao接口的地址

Dao接口的方法名和mapper.xml中的statement的 id一致

Dao.java接口中的方法输入参数类型和mapper.xml中statement的paramterType指定的类型一致

Dao.java接口中的方法输出参数类型和mapper.xml中statement的ResultType指定的类型一致

Test:

public class BookDaoTest {

private SqlSessionFactory sqlSessionFactory;

@Before

public void setUp() throws IOException{

String resource="mybatis-config.xml";

InputStream inputStream=Resources.getResourceAsStream(resource);

sqlSessionFactory=new SqlSessionFactoryBuilder().build(inputStream);

}

@Test

public void testLoadByName() throws Exception{

SqlSession sqlSession=sqlSessionFactory.openSession();

//创建IBookDao对象,自动生成mapper代理对象

IBookDao bookDao=sqlSession.getMapper(IBookDao.class);

Book book=bookDao.loadById(5);

System.out.println(book);

}

}

Mybatis-config.xml的详细配置

properties(属性)

settings(全局配置参数)

typeAliases(类型别名)

typeHandlers(类型处理器)

objectFactory(对象工厂)

plugins(插件)

environments(环境集合属性对象)

environment(环境子属性对象)

transactionManager(事务管理)

dataSource(数据源)

mappers(映射器)

详细参数配置,下篇文章详解哦~

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20180106G0QV7800?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券