前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mybatis入门

Mybatis入门

作者头像
xiaozhangStu
发布2023-05-04 19:22:21
2020
发布2023-05-04 19:22:21
举报
文章被收录于专栏:xiaozhangStuxiaozhangStu

Mybatis入门

概述

一个半自动化的ORM框架,他是作用于DAO层,拥有强大的动态sql的能力,小巧灵活,简单易学

框架

ORM

编写程序的时候,以面向对象的方式处理数据 保存数据的时候,却以关系型数据库的方式存储

ORM解决方案

在持久化对象上执行基本的增、删、改、查操作 对持久化对象提供一种查询语言或者API 对象关系映射工具 提供与事务对象交互、执行检查、延迟加载以及其他优化功能

开发步骤

  1. 下载mybatis-3.2.2.jar包并导入工程
  2. 编写MyBatis核心配置文件(configuration.xml)
  3. 创建实体类-POJO
  4. DAO层-SQL映射文件(mapper.xml)
  5. 创建测试类 读取核心配置文件mybatis-config.xml 创建SqlSessionFactory对象,读取配置文件 创建SqlSession对象 调用mapper文件进行数据操作

核心对象

SqlSessionFactoryBuilder

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

代码语言:javascript
复制
读取XML文件构造方式:
String resource = "mybatis-config.xml";   
InputStream is = Resources.getResourceAsStream(resource);   
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
​
代码语言:javascript
复制
build(InputStream inputStream, String environment, Properties properties) 
build(Reader reader, String environment, Properties properties)
build(Configuration config)
​
配置信息以三种形式提供给SqlSessionFactory的build方法:
InputStream (字节流)、Reader(字符流)、Configuration(类)
​
SqlSessionFactory

SqlSessionFactory是每个MyBatis应用的核心 作用:创建SqlSession实例

代码语言:javascript
复制
SqlSession session = sqlSessionFactory.openSession(boolean autoCommit);

作用域:Application 生命周期与应用的生命周期相同 单例 存在于整个应用运行时,并且同时只存在一个对象实例

SqlSession

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

代码语言:javascript
复制
SqlSession session = sqlSessionFactory.openSession();
try {
      // do work
} finally {
     session.close();
}

关闭SqlSession非常重要,必须要确保在finally方法体中正常关闭

整体创建方式
代码语言:javascript
复制
String resource = "mybatis-config.xml";   
InputStream  is = Resources.getResourceAsStream(resource);   
SqlSessionFactory factory = new SqlSessionFactoryBuilder().build(is) ;
SqlSession sqlSession = factory.openSession();
SqlSession的两种使用方式

通过SqlSession实例直接运行映射的SQL语句 基于Mapper接口方式操作数据

系统核心配置文件

configuration 配置
properties 可以配置在Java 属性配置文件中

通过外部指定的方式(database.properties),实现动态配置

代码语言:javascript
复制
<properties resource="database.properties"/>      
......
<dataSource type="POOLED">
    <property name="driver" value="${driver}"/>
    <property name="url" value="${url}"/>
    <property name="username" value="${user}"/>
    <property name="password" value="${password}"/>
</dataSource>
​

直接配置为xml,实现动态配置

代码语言:javascript
复制
<properties>
        <property name="driver" value="com.mysql.jdbc.Driver"/>
        <property name="url" value="jdbc:mysql://127.0.0.1:3306/smbms"/>
        <property name="user" value="root"/>
        <property name="password" value="root"/>
</properties>
......
<dataSource type="POOLED">
        <property name="driver" value="${driver}"/>
        <property name="url" value="${url}"/>
        <property name="username" value="${user}"/>
        <property name="password" value="${password}"/>
</dataSource>
​

resource属性值的优先级高于property子节点配置的值

settings 修改 MyBatis 在运行时的行为方式

用来修改MyBatis运行时的行为方式 主要是MyBatis的一些全局配置属性的设置

设置项

描述

允许值

默认值

cacheEnabled

对在此配置文件下的所有cache进行全局性开/关设置

true | false

true

lazyLoadingEnabled

全局性设置懒加载。如果设为‘false’,则所有相关联的都会被初始化加载

true | false

true

autoMappingBehavior

MyBatis对于resultMap自动映射匹配级别

NONE |PARTIAL |FULL

PARTIAL

typeAliases 为 Java 类型命名一个别名(简称)

类型别名 仅仅只关联XML配置,简写冗长的Java类名

代码语言:javascript
复制
<typeAliases>
    <typeAlias alias="User" type="cn.smbms.pojo.User"/>
</typeAliases>
​
代码语言:javascript
复制
<typeAliases>
    <package name ="cn.smbms.pojo" />
</typeAliases>
typeHandlers 类型处理器
objectFactory 对象工厂
plugins 插件
environments 环境

表示配置MyBatis的多套运行环境,将SQL映射到多个不同的数据库上 子元素节点:environment,但是必须指定其中一个为默认运行环境(通过default指定)

代码语言:javascript
复制
<environments default="development">
<environment id="development">
<transactionManager type="JDBC"/>
<dataSource type="POOLED">
            <property name="driver" value="${driver}"/>
         <property name="url" value="${url}"/>
            <property name="username" value="${user}"/>
            <property name="password" value="${password}"/>
</dataSource>
</environment>
<environment id="test">
……
</environment>
</environments>
​
environment 环境变量
transactionManager 事务管理器
代码语言:javascript
复制
<transactionManager type="[ JDBC | MANAGED ]" />
dataSource 数据源

dataSource dataSource元素使用基本的JDBC数据源接口来配置JDBC连接对象的资源 有三种内建的数据源类型

代码语言:javascript
复制
<dataSource type=" [UNPOOLED | POOLED | JNDI]" />
代码语言:javascript
复制
<dataSource type="POOLED">
    <property name="driver" value="${driver}"/>
    <property name="url" value="${url}"/>
    <property name="username" value="${user}"/>
    <property name="password" value="${password}"/>
</dataSource>
mappers 映射器

映射器,定义SQL映射语句 须在配置中引用mapper映射文件

方式一

使用类资源路径获取资源

代码语言:javascript
复制
<!-- 将mapper映射文件加入到系统核心配置文件中 -->
<mappers>
    <mapper  resource="cn/smbms/dao/user/UserMapper.xml"/>
</mappers>
方式二

使用URL获取资源

代码语言:javascript
复制
<mappers>
        <mapper url="file:///E:/sqlmappers/UserMapper.xml"/>
        <mapper url="file:///E:/sqlmappers/ProviderMapper.xml"/>
</mappers>

SQL映射文件

下章节见

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-02-14,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Mybatis入门
    • 概述
      • ORM
        • ORM解决方案
          • 开发步骤
            • 核心对象
              • 系统核心配置文件
                • SQL映射文件
                相关产品与服务
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档