Mybatis的介绍及使用

news2025/1/16 8:07:50

目录

Mybatis

搭建MyBatis开发环境

1、创建Maven工程,导入MyBatis依赖的组件

2、编写MyBatis核心配置文件(mybatis-config.xml)

3、创建实体类-POJO

4、创建SQL映射文件(mapper.xml)

5、创建测试类


Mybatis

MyBatis是一款优秀的持久层框架,用于简化JDBC开发
MyBatis 本是 Apache的一个开源项目iBatis, 2010年这个项目由apache softwarefoundation迁移到了google code,并且改名为MyBatis。2013年11月迁移到Github

官网:mybatis – MyBatis 3 | 入门

持久层

负责将数据到保存到数据库的那一层代码

JavaEE三层架构:表现层、业务层、持久层

框架

框架就是一个半成品软件,是一套可重用的、通用的、软件基础代码模型

在框架的基础之上构建软件编写更加高效、规范、通用、可扩展

JDBC缺点

1.硬编码:注册驱动,获取连接,SQL语句

2.操作繁琐:手动设置参数,手动封装结果集

Mybatis特点

1、基于SQL语法,简单易学

2、能了解底层封装过程,内部通过JDBC访问数据库的操作

3、SQL语句封装在配置文件中,便于统一管理与维护,降低程序的耦合度

4、方便程序代码调试

ORM(Object Relational Mapping)

对象/关系映射,是一种数据持久化技术。它在对象模型关系型数据库之间建立起对应关系,

并且提供了一种机制,通过JavaBean对象去操作数据库表中的数据。

编写程序的时候,以面向对象的方式处理数据。

保存数据的时候,却以关系型数据库的方式存储。

ORM解决方案包含下面四个部分:

1、在持久化对象上执行基本的增、删、改、查操作

2、对持久化对象提供一种查询语言或者API

3、对象关系映射工具

4、提供与事务对象交互、执行检查、延迟加载以及其他优化功能

搭建MyBatis开发环境

1、创建Maven工程,导入MyBatis依赖的组件

找到pom.xml在dependencies中添加依赖 

2、编写MyBatis核心配置文件(mybatis-config.xml)

configuration 配置
properties    可以配置在Java 属性配置文件中
settings    修改 MyBatis 在运行时的行为方式
typeAliases  Java 类型命名一个别名(简称)
typeHandlers  类型处理器
objectFactory  对象工厂
plugins   插件
environments   环境
environment   环境变量
transactionManager 事务管理器
dataSource  数据源
mappers    映射器

 配置properties元素的两种方式

1、通过外部指定的方式,即配置在典型的Java属性文件中(如:database.properties),实现动态配置

2、直接配置为xml,并使用这些属性对配置项实现动态配置

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

配置propertiesresource属性

<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=“aptech"/>
</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>

 若两种方式同时都用了,那么哪种方式优先?

配置propertiesresource指定

配置propertynamevalue

<properties resource="database.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>

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

settings元素

作用:是设置一些非常重要的设置选项,用来设置和改变MyBatis运行时的行为方式 

设置项

描述

允许值

默认值

cacheEnabled

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

true | false

true

lazyLoadingEnabled

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

true | false

true

autoMappingBehavior

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

NONE |

PARTIAL |

FULL

PARTIAL

typeAliases元素

作用:配置类型别名,通过与MyBatis的SQL映射文件相关联,减少输入 多余的完整类名,以简化操作。

<typeAliases>
	<package name ="cn.smbms.pojo" />
</typeAliases>

 environments元素

表示配置MyBatis的多套运行环境,将SQL映射到多个不同的数据库上

子元素节点:environment,但是必须指定其中一个默认运行环境(通过default指定)

注意:每个SqlSessionFactory实例只能选择一个运行环境

dataSource

dataSource元素使用基本的JDBC数据源接口来配置JDBC连接对象的资源

有三种内建的数据源类型

<dataSource type=" [UNPOOLED | POOLED | JNDI]" />
<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映射文件

方式一:使用类资源路径获取资源

<!-- 将mapper映射文件加入到系统核心配置文件中 -->
<mappers>
	<mapper  resource="cn/smbms/dao/user/UserMapper.xml"/>
</mappers>

 方式二:使用URL获取资源

<mappers>
		<mapper url="file:///E:/sqlmappers/UserMapper.xml"/>
		<mapper url="file:///E:/sqlmappers/ProviderMapper.xml"/>
</mappers>

3、创建实体类-POJO

4、创建SQL映射文件(mapper.xml)

SQL映射文件的几个顶级元素(按照定义的顺序)

mappernamespace
cache配置给定命名空间的缓存
cache-ref从其他命名空间引用缓存配置
resultMap用来描述数据库结果集和对象的对应关系
sql可以重用的SQL块,也可以被其他语句引用
insert 映射插入语句
update映射更新语句
delete映射删除语句
select映射查询语句

mapper

namespace:命名空间

namespace和子元素的id联合保证唯一,区别不同的mapper

绑定DAO接口

namespace的命名必须跟某个接口同名

接口中的方法与映射文件中SQL语句id一一对应

示例:

<mapper namespace="cn.cvs.dao.sysuser.SysUserMapper">
	<select id="getUserList" …
		……
	</select>
</mapper>

select语句有很多属性可以详细配置每一条语句

id:命名空间中唯一的标识符

接口中的方法与映射文件中的SQL语句id一一对应

parameterType:

表示查询语句传入参数的类型的完全限定名和别名

支持基础数据类型和复杂数据类型

resultType

SQL语句返回值类型的完整限定名或别名

示例:仅传入一个简单数据类型的查询条件,如一个基本类型或其包装类型,或一个String类型等,MyBatis框架的处理方式也非常简单。需求:根据真实姓名模糊查询用户信息

1.SysUserMapper接口中添加查询方法

List<SysUser>  getUserListByRealName(String realName);

2SysUserMapper.xml中添加SQL语句映射

select * from t_sys_user where realName like CONCAT ('%', #{param}, '%')

 3、在单元测试类中添加测试方法

List<SysUser> userList =sqlSession.getMapper(SysUserMapper.class) .getUsersByRealName("李");

别名与Java类型映射

别名映射的类型
stringString
byteByte
longLong
shortShort
doubleDouble
floatFloat
booleanBoolean
date

Date

intInteger

integer

Integer
arraylistArrayList
mapMap
listList

collection

Collection
iteratorIterator
decimalBigDecimal
bigdecimalBigDecimal
objectObject

……

……

parameterType

基础数据类型

int、StringDate等,一个参数传递单一数值

用@Param注解为参数命名,通过 #{参数名} 获取传入的值

复杂数据类型

Java实体类,Map

通过#{属性名}或者#{mapkeyName}即可获取传入值

resultType :直接表示返回类型

基本数据类型

复杂数据类型

resultMap :对外部resultMap的引用

应用场景:

数据库字段信息与对象属性不一致

复杂的联合查询,自由控制映射结果

二者不能同时存在,本质上都是Map数据结构

resultMap自动映射匹配前提:字段名与属性名一致

resultMap的自动映射级别-autoMappingBehavior

PARTIAL(默认):自动匹配所有

NONE:进制自动匹配

<settings>
	<setting  name="autoMappingBehavior" value="NONE"/>
</settings>

 insert属性:id、parameterType

<insert  id="add" parameterType="User" >
 insert into  smbms_user (userCode,userName,userPassword) 
		values ( #{userCode},#{userName},#{userPassword})
</insert>

 注意:insertupdatedelete元素均没有resultType属性

update属性:id、parameterType

<update id ="modify" parameterType="User">
update smbms_user set userCode = #{userCode},
	         userName = #{userName},
              userPassword = #{userPassword}  where id = #{id}
</update>

 delete属性:id、parameterType

<delete id ="deleteUserById" parameterType="int">
	delete from smbms_user where id = #{id}
</delete>

 resultMap属性

id:resultMap的唯一标识

type:Java实体类

resultMap子元素

id:一般对应数据库中该行的主键id,设置此项可提高MyBatis性能

result:映射到JavaBean的某个“简单类型”属性

association:映射到JavaBean的某个“复杂类型”属性,比如JavaBean

collection:映射到JavaBean的某个“复杂类型”属性,比如集合

association

复杂的类型关联,一对一

内部嵌套:映射一个嵌套JavaBean属性

属性

property:映射数据库列的实体对象的属性

javaType:完整Java类名或者别名

resultMap:引用外部resultMap

子元素:id、result

property:映射数据库列的实体对象的属性

column:数据库列名或者别名

collection

复杂类型集合,一对多

内部嵌套、映射一个嵌套结果集到一个列表

属性

property:映射数据库列的实体对象的属性

ofType:完整Java类名或者别名(集合所包括的类型)

resultMap:引用外部resultMap

子元素:id、result

property:映射数据库列的实体对象的属性

column:数据库列名或者别名

5、创建测试类

1、读取核心配置文件mybatis-config.xml

2、创建SqlSessionFactory对象,读取配置文件

3、创建SqlSession对象

4、调用mapper文件进行数据操作

SqlSessionFactory

SqlSessionFactory是每个MyBatis应用的核心

作用:创建SqlSession实例

SqlSessionFactory工具类

public class MybatisUtil {
    private static SqlSessionFactory sqlSessionFactory;
    static {
        String mybatisPath = "mybatis/mybatis-config.xml";
        //1、加载mybatis配置文件
        InputStream is = null;
        try {
            is = Resources.getResourceAsStream(mybatisPath);
        } catch (IOException e) {
            e.printStackTrace();
        }
        //2、根据mybatis配置文件,创建生成SqlSession的factory工厂
        sqlSessionFactory = new SqlSessionFactoryBuilder().build(is);
    }
    public static SqlSession createSqlSession(){
        if (sqlSessionFactory != null){
            return sqlSessionFactory.openSession();
        }
        return null;
    }
    public static void closeSqlSession(SqlSession sqlSession){
        if (sqlSession != null){
            sqlSession.close();
        }
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/48591.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

时光邮局|来写一封未来的信试试吧!一个我的新项目,Java+Vue

什么是时光邮局&#xff1f; 漫漫星河璀璨&#xff0c;漫漫古道长河。 官网&#xff1a;云寄-时光邮局 寻找一份特殊的意义&#xff0c;学会热爱生活&#xff0c;学会面朝大海。 有一天我收到了两年前的自己来信。 如果可以给末来寄信你会写些什么呢&#xff1f; 如果能收到两…

分析网上的一篇“浪漫烟花“程序<VS-C++>

结果:多个烟花弹同时上升,然后进行爆炸,并进行了花样设计,采取心型设计方案,背景音乐设置为"小幸运",除此在最初,窗口设置有文本. 接下来,就让我们来分析代码: // 烟花结构 struct FIRE {int r; // 当前爆炸半径int max_r; // 爆炸中心距离边缘最大半径int …

简述RabbitMQ的架构设计

Broker&#xff1a; rabbitmq的服务节点Queue&#xff1a; 队列&#xff0c;是RabbitMQ的内部对象&#xff0c;⽤于存储消息。RabbitMQ中消息只能存储在队列中。⽣产者投递消息到队列&#xff0c;消费者从队列中获取消息并消费。多个消费者可以订阅同⼀个队列&#xff0c;这时队…

Windows系统--AD域控--DHCP服务器

Windows系统--AD域控--DHCP服务器 虚拟机网络准备 1.将VMware网络编辑器的NAT模式--取消勾选 使用本地DHCP服务器; 从机(win10)将内置网卡的IPv4网络改为 自动获取IP地址、自动获取DNS AD服务器 部署 DHCP服务器

springboot+java+vue.js教室自习室座位预订系统

目 录 摘 要 I Abstract II 第1章 前 言 2 1.1 研究背景 3 1.2 研究现状 3 1.3 系统开发目标 3 第2章 系统开发环境 5 2.1 java技术 5 2.2 Mysql数据库 6 2.3 B/S结构 7 2.4 springboot框架 7 2.5 ECLIPSE 开发环境 7 第3章 需…

MyBatis ---- MyBatis获取参数值的两种方式(重点)

MyBatis ---- MyBatis获取参数值的两种方式&#xff08;重点&#xff09;1. 单个字面量类型的参数2. 多个字面量类型的参数3. map集合类型的参数4. 实体类类型的参数5. 使用Param标识参数MyBatis 获取参数值的两种方式&#xff1a;${} 和 #{} ${}&#xff1a;本质就是字符串拼…

swift 闭包closure 省略

闭包 表达式 reversedNames names.sorted(by: { (s1: String, s2: String) -> Bool inreturn s1 > s2 }) 可省略的地方 省略返回类型 没有参数可以省略 in 这一样 省略参数类型 省略圆括号&#xff0c;这个是如果就一个参数&#xff0c;并且我们编译器可以推断出其类型…

Python基础(一)基本类型

一、Number数字 1.1 注意事项 Python支持int、float、bool和complex类型。 complex是复数类型abj&#xff08;或complex(a,b))&#xff0c;a表示实部&#xff0c;b表示虚部&#xff0c;a b本身是float类型。 Python使用变量时&#xff0c;无需声明变量。 a3 # 自动声明为i…

微信小程序|基于小程序+C#制作一个电子书阅读器

文章目录一、文章前言二、开发流程2.1、开发工具2.2、页面实现2.3、数据库设计2.4、API实现一、文章前言 书籍是人类进步的阶梯&#xff0c;各位小伙伴在使用市面上各类阅读器进行阅读的时候是否有被层出不穷的广告或者及其不友好的用户体验所困扰呢&#xff0c;为何不制作一个…

矢量网络分析仪是什么?矢量网络分析仪的组成

一、矢量网络分析仪是什么 矢量网络分析仪是一款高性能、大动态范围、低噪声的矢量网络分析仪。频率范围涵盖整个移动通信频段&#xff0c;全双端口S参数测量&#xff0c;测量精度高&#xff0c;测试稳定性好&#xff0c;测量速度快。 用途&#xff1a;可广泛应用于移动通信、军…

realme手机适合什么蓝牙耳机?适合realme手机的蓝牙耳机推荐

自从众多手机厂商取消3.5mm耳机接口之后&#xff0c;蓝牙耳机作为人们通勤、旅行时经常携带的设备&#xff0c;realme手机近几年也受到很多人的喜爱&#xff0c;那么在品牌众多的蓝牙耳机中如何挑选出最适合自己的呢&#xff1f;今天小编就来为大家分享几款适合realme手机的蓝牙…

天翼云Serverless边缘容器下沉服务 促进企业聚焦业务创新

当前,我国经济社会各领域正加速向数字化转型迈进,随之涌现出海量的数据处理需求在边缘侧不断产生。根据信通院发布的数据显示,2021年我国边缘计算市场规模已经达到436.4亿元,其中边缘硬件规模市场为290.2亿元,边缘软件与服务市场规模达146.2亿元,年平均增速超过50%,预计2024年边…

包装类和泛型

包装类和泛型严格来说算得上是JavaSE的内容&#xff0c;为什么他们要放在数据集合中&#xff1f; 这和集合类有关&#xff0c;我们在集合类中将会用到大量的泛型和包装类。 1. 包装类 基本介绍 包装类&#xff08;wrapper&#xff09;是针对八大基本数据类型相应的引用类型…

云安全系列4:解析云安全工具集

随着组织越来越多地将数据和应用转移到云端&#xff0c;云安全在确保工作负载安全方面变得至关重要。Gartener 就表示&#xff1a;“云优先战略现在已十分普遍&#xff0c;甚至在不愿承担风险的企业机构中也是如此。但由于缺乏确保安全云计算部署所必需的技能和工具&#xff0c…

pytest文档83 - 把收集的 yaml 文件转 Item 用例并运行

前言 上一篇通过用例收集钩子 pytest_collect_file 把 yaml 文件收集起来的&#xff0c;仅仅只是收集到用例&#xff0c;还不能执行。 接下来详细讲解&#xff0c;如何把yaml 文件的内容&#xff0c;转成Item 用例去执行。 pytest_collect_file 收集钩子 准备一个待执行的YA…

Oracle SQL执行计划操作(12)——DDL及DML相关操作

14. DDL及DML相关操作 该类操作与DDL及DML类SQL语句相关。根据不同的具体SQL语句及其他相关因素,如下各操作可能会出现于相关SQL语句的执行计划。另需注意,该类操作会造成数据库对象或数据的改变。 1)CREATE TABLE STATEMENT 创建数据表。该操作出现于通过create[global …

PHP 开发-XAMPP 安装

开发环境&#xff1a;Windows10&#xff0c;XAMPP&#xff08;x64-7.4.33&#xff09;&#xff0c;Netbeans。 XAMPP 安装 官网下载XAMPP安装包&#xff0c;我下载的版本 x64-7.4.33。安装包中相关软件版本&#xff08;官网上可查询&#xff09;&#xff1a; Apache 2.4.54M…

Java并发编程--变量可见性、避免指令重排,还得是用它

那怎么保证程序里一个线程对共享变量的修改能立马被其他线程看到了&#xff1f;这时候有人会说了&#xff0c;加锁呀&#xff0c;前面不就是因为加锁成本太高才使用的 ThreadLocal的吗&#xff1f;怎么又说回去了&#xff1f; 其实CPU每个核心也都是有缓存的&#xff0c;今天要…

基于el-form实现自动展开/收起的查询条件组件

说明 如果查询条件过多&#xff0c;影响页面的展示效果&#xff0c;网上看了一些实现自动展开/收起的&#xff0c;有根据最小高度控制的&#xff0c;有基于条件的如v-show来控制&#xff0c;下面借助js原生的hidden属性实现要素的显示、隐藏控制。 先一下效果&#xff1a; 优…

web扫码登录

文章目录需求流程交互流程服务交互流程关键思路代码生成二维码&#xff0c;返回给PC展示轮询查询二维码状态APP扫码请求登录总结需求 pc端实现app扫码登录 流程 交互流程 服务交互流程 关键思路 主要问题在于如何识别APP端用户&#xff0c;然后传递给PC端已经登录成功 通过…