前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >优秀的持久层框架-Mybatis框架解析

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

作者头像
企鹅号小编
发布2018-02-08 09:34:05
7070
发布2018-02-08 09:34:05
举报
文章被收录于专栏:企鹅号快讯

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(映射器)

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

本文来自企鹅号 - 程序员食堂媒体

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文来自企鹅号 - 程序员食堂媒体

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档