博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mybatis 的使用和配置
阅读量:6554 次
发布时间:2019-06-24

本文共 9444 字,大约阅读时间需要 31 分钟。

hot3.png

MyBatis 是一款优秀的持久层框架,它支持定制化 SQL、存储过程以及高级映射。MyBatis 有以下特点:

  • 简单易学,小且简单:没有第三方依赖,最简单安装只要两个jar包+配置几个sql映射文件,通过文档和源代码,可以比较完全的掌握它的设计思路和实现。
  • 灵活:mybatis不会对应用程序或者数据库的现有设计强加任何影响。 sql写在xml里,便于统一管理和优化。通过sql语句可以满足操作数据库的所有需求。
  • 解除sql与程序代码的耦合:通过提供DAO层,将业务逻辑和数据访问逻辑分离,使系统的设计更清晰,更易维护,更易单元测试。sql和代码的分离,提高了可维护性。
  • 提供映射标签,支持对象与数据库的orm字段关系映射
  • 提供对象关系映射标签,支持对象关系组建维护
  • 提供xml标签,支持编写动态sql。

一、快速入门实例

1、引用依赖

单独使用 mybatis,只需引入mybatis-x.x.x.jar 和相关的数据库连接包就行。

使用 maven 的 dependency 配置为

org.mybatis
mybatis
3.4.6

我的例子的应用目录结构为下图

2、mybatis配置和 xml映射文件配置

每个基于 MyBatis 的应用都是以一个SqlSessionFactory的实例为中心的。

SqlSessionFactory 的实例可以通过 SqlSessionFactoryBuilder获得。
SqlSessionFactoryBuilder 则可以从 XML 配置文件或一个预先定制的 Configuration 的实例构建出 SqlSessionFactory 的实例。

1)mybatis XML 配置

MyBatis 的XML配置文件(configuration XML)中包含了对 MyBatis 系统的核心设置,包含获取数据库连接实例的数据源(DataSource)和决定事务作用域和控制方式的事务管理器(TransactionManager)

这里先给出一个用 xml 配置的简单示例 mybatis-config.xml,详细的配置文件内容后面详说:

数据源属性文件 database.properties

jdbc.driver=com.mysql.jdbc.Driverjdbc.url=jdbc:mysql://localhost:3306/shiyu?autoReconnect=true&useUnicode=true&characterEncoding=utf-8jdbc.username=zoujdbc.password=******

通过配置文件我们可以从中构建 SqlSessionFactory 的实例

inputStream = Resources.getResourceAsStream("conf/mybatis-config.xml");sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

2) xml映射文件配置

我们从上面的配置可以看到有映射器的配置

<mapper resource="com/brave/dao/mapper/UpmsUserMapper.xml" />

这里先给出该映射文件示例

insert into upms_user (user_id,loginname,password,realname,is_locked) value(#{userId},#{loginname},#{password},#{realname},#{locked})

上面我们通过 mybatis配置xml 构建了SqlSessionFactory,有了 SqlSessionFactory,顾名思义,我们就可以从中获得 SqlSession 的实例了。SqlSession 完全包含了面向数据库执行 SQL 命令所需的所有方法。你可以通过 SqlSession 实例来直接执行已映射的 SQL 语句:

SqlSession sqlSession = sqlSessionFactory.openSession();try {    //这里我们通过 命名空间+sql语句的Id来执行映射的sql语句    UpmsUser upmsUser = sqlSession.selectOne("com.brave.dao.UpmsUserDao.selectOne", 10001L);}finally {    sqlSession.close();}

3、构建 SqlSessionFactory,获取 SqlSession

从上面的 mybatis配置和 xml映射文件配置 我们可以了解到这样一个流程:

通过流读取 mabatis 配置文件信息,使用 SqlSessionFactoryBuilder 构建 SqlSessionFactory,再从SqlSessionFactory 中获取 SqlSession 实例,通过 SqlSession 实例来直接执行已映射的 SQL 语句

在这里我们需要理解这三个对象的不同作用域和生命周期,错误的使用会导致非常严重的并发问题。

生命周期 作用域(Scope)
SqlSessionFactoryBuilder 可以被实例化、使用和丢弃,一旦创建了 SqlSessionFactory,就不再需要它了 方法(也就是局部方法变量)
SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,没有任何理由对它进行清除或重建 应用(最简单的就是使用单例模式或者静态单例模式)
SqlSession 每个线程都应该有它自己的 SqlSession 实例。SqlSession 的实例不是线程安全的,因此是不能被共享的 请求 / 方法

因为 SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,我们可以使用单例,创建一个 SqlSessionFactoryUtil

public class SqlSessionFactoryUtil {    private static SqlSessionFactory sqlSessionFactory;    /**     * 每个基于 MyBatis 的应用都是以一个 SqlSessionFactory 的实例为中心的。     * SqlSessionFactory 的实例可以通过 SqlSessionFactoryBuilder 获得。     * 而 SqlSessionFactoryBuilder 则可以从 XML 配置文件或一个预先定制的 Configuration 的实例构建出 SqlSessionFactory 的实例。     *      * SqlSessionFactoryBuilder 最佳作用域是方法作用域(也就是局部方法变量)      * SqlSessionFactory 最佳作用域是应用作用域      * SqlSession 最佳的作用域是请求或方法作用域     */    public static SqlSessionFactory getSqlSessionFactory() {        if (sqlSessionFactory != null) {            return sqlSessionFactory;        }        InputStream inputStream;        try {            inputStream = Resources.getResourceAsStream("conf/mybatis-config.xml");            sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);        } catch (IOException e) {            e.printStackTrace();        }        return sqlSessionFactory;    }}

我们可以创建一个 baseDao 获取 SqlSession

public class BaseDaoImpl implements BaseDao {    @Override    public SqlSession getSqlSession() {        SqlSessionFactory sqlSessionFactory = SqlSessionFactoryUtil.getSqlSessionFactory();        return sqlSessionFactory.openSession();    }}

通过 命名空间+sql语句的Id来执行映射的sql语句

public class UpmsUserDaoImpl extends BaseDaoImpl implements UpmsUserDao {    @Override    public UpmsUser selectOne(Long userId) {        SqlSession sqlSession = getSqlSession();        UpmsUser upmsUser = null;        try {            upmsUser = sqlSession.selectOne("com.brave.dao.UpmsUserDao.selectOne", userId);        } finally {            sqlSession.close();        }        return upmsUser;    }    @Override    public List
selectUser() { SqlSession sqlSession = getSqlSession(); List
upmsUsers = null; try { upmsUsers = sqlSession.selectList("com.brave.dao.UpmsUserDao.selectUser"); } finally { sqlSession.close(); } return upmsUsers; } @Override public int insertUser(UpmsUser upmsUser) { SqlSession sqlSession = getSqlSession(); int n = 0; try { n = sqlSession.insert("com.brave.dao.UpmsUserDao.insertUser", upmsUser); sqlSession.commit(); } finally { sqlSession.close(); } return n; }}

我们用 Junit 创建测试类测试一下结果

public class UpmsUserDaoImplTest {     UpmsUserDao userDao = new UpmsUserDaoImpl();    @Test    public void testSelectOne() {        System.out.println(userDao.selectOne(10001L).toString());    }    @Test    public void testSelectUser() {        List
upmsUsers = userDao.selectUser(); for (UpmsUser upmsUser : upmsUsers) { System.out.println(upmsUser.toString()); } } @Test public void testInsertUser() { UpmsUser upmsUser = new UpmsUser(); upmsUser.setUserId(10002L); upmsUser.setLoginname("zou"); upmsUser.setPassword("123456"); upmsUser.setLocked(false); int n = userDao.insertUser(upmsUser); System.out.println("插入" + n + "行"); }}

到了这里我们其实可以发现,我们在映射文件中写的 命名空间 和 完全限定名 是一样的,如com.brave.dao.UpmsUserDao ,这个命名可以直接映射到在命名空间中同名的 Mapper 类,并将已映射的 sql 语句中的名字、参数和返回类型匹配成方法 这样我们就可以像上面那样很容易地调用这个对应 Mapper 接口的方法,只需要接口,不需要写实现类。我们的接口方法名称和 映射文件中的sql语句Id一致的话可以直接调用。

UpmsUserDao.java

public interface UpmsUserDao extends BaseDao {    UpmsUser selectOne(Long userId);    List
selectUser(); int insertUser(UpmsUser upmsUser);}

测试

@Testpublic void testInterface() {    SqlSessionFactory sqlSessionFactory = SqlSessionFactoryUtil.getSqlSessionFactory();    SqlSession session = sqlSessionFactory.openSession();    //可以直接映射到在命名空间中同名的 Mapper 类 (只要映射接口类就可以了,不需要实现)    UpmsUserDao upmsUserDao = session.getMapper(UpmsUserDao.class);    List
upmsUsers = upmsUserDao.selectUser(); for (UpmsUser upmsUser : upmsUsers) { System.out.println(upmsUser.toString()); }}

它们的映射的语句还可以不需要用 XML 来做,取而代之的是可以使用 Java 注解

@Select("select * from upms_user where user_id = #{userId}")UpmsUser getUser(Long userId);

二、SqlSession 的使用和API

使用 MyBatis 的主要 Java 接口就是 SqlSession。可以通过这个接口来执行命令,获取映射器和管理事务。SqlSessions 是由 SqlSessionFactory 实例创建的。SqlSessionFactory 对象包含创建 SqlSession 实例的所有方法。而 SqlSessionFactory 本身是由 SqlSessionFactoryBuilder 创建的,它可以从 XML、注解或手动配置 Java 代码来创建 SqlSessionFactory。

三、MyBatis XML配置

MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置(settings)和属性(properties)信息。文档的顶层结构如下:

  • configuration 配置
    • properties 属性
    • settings 设置
    • typeAliases 类型别名
    • typeHandlers 类型处理器
    • objectFactory 对象工厂
    • plugins 插件
    • environments 环境
      • environment 环境变量
      • transactionManager 事务管理器
      • dataSource 数据源
    • databaseIdProvider 数据库厂商标识
    • mappers 映射器

官方的文档很详细,这里不写了,直接参考过去

四、Mapper映射文件配置

MyBatis 的真正强大在于它的映射语句,也是它的魔力所在。由于它的异常强大,映射器的 XML 文件就显得相对简单。如果拿它跟具有相同功能的 JDBC 代码进行对比,你会立即发现省掉了将近 95% 的代码。MyBatis 就是针对 SQL 构建的,并且比普通的方法做的更好。

SQL 映射文件有很少的几个顶级元素(按照它们应该被定义的顺序):

  • cache – 给定命名空间的缓存配置。
  • cache-ref – 其他命名空间缓存配置的引用。
  • resultMap – 是最复杂也是最强大的元素,用来描述如何从数据库结果集中来加载对象。
  • parameterMap – 已废弃!老式风格的参数映射。内联参数是首选,这个元素可能在将来被移除,这里不会记录。
  • sql – 可被其他语句引用的可重用语句块。
  • insert – 映射插入语句
  • update – 映射更新语句
  • delete – 映射删除语句
  • select – 映射查询语句

每个元素的细节见官方文档

转载于:https://my.oschina.net/morgan412/blog/2998402

你可能感兴趣的文章
sql语句
查看>>
android 一步一步教你集成tinker(热修复)
查看>>
到底有多少内存
查看>>
centos7.3 安装ovirt-engine4.0 版本
查看>>
putty、xshell的密钥认证
查看>>
Jenkins+git+tomcat 自动化持续部署
查看>>
项目log日志打印
查看>>
Openstack的环境的Mitaka部署环境服务,实例(1)
查看>>
Redis总结(七)Redis运维常用命令
查看>>
常用shell
查看>>
文档的压缩与打包
查看>>
python3 在不同操作系统安装第三方库方法
查看>>
redhat5.8+mfs(提供软件包文档)
查看>>
python编写登录接口
查看>>
MySQL高可用方案之多级复制
查看>>
OVS 中的各种网络设备 - 每天5分钟玩转 OpenStack(128)
查看>>
Python火车票代码
查看>>
Android开发者指南(7) —— App Install Location
查看>>
Trafficserver Cluster模式
查看>>
亚马逊推出 Blox,用于 EC2 容器服务的开源工具集合
查看>>