Mybatis 系列全解(1)——全网免费最细最全,手把手教,学完就可做项目!

Mybatis 系列全解(1)

  • 1. 第一个小程序
  • 2. CURD 增删改查
  • 3. 模糊查询
  • 4. 配置解析
    • 4.1 核心配置文件
    • 4.2 环境配置
    • 4.3 属性
    • 4.4 类型别名
    • 4.5 设置
    • 4.6 映射器 mappers

1. 第一个小程序

1)创建一个数据库,一个表,填入一些数据。(这里不做演示,可以参考我前面写的数据库文章有具体介绍:在介绍DDL数据库操作中有创建数据库代码,链接:DDL数据库操作,或者在介绍数据库的约束中举例介绍了加上约束创建数据库,链接:约束)。

2)新建一个普通的maven项目

3)删除src项目

4)搭建环境

  • 在pom.xml中导入依赖:
<dependencies><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.6</version></dependency><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.1</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency>
</dependencies>

5)创建一个module模块(子模块)

  • 编写mybatis的核心配置文件

    在resources下创建mybatics-config.xml写入

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration><environments default="development"><environment id="development"><transactionManager type="JDBC"/><dataSource type="POOLED"><property name="driver" value="com.mysql.jdbc.Driver"/><property name="url" value="jdbc:mysql://localhost:3306/mybatis?useSSl=true&amp;useUnicode=true&amp;characterEncoding=UTF-8"/><property name="username" value="root"/><property name="password" value="root"/></dataSource></environment></environments><mappers><mapper resource="com/kuang/dao/UserMapper.xml"/>
</mappers>
</configuration>

       注:mappers 标签不写会报错“Type interface com.kuang.dao.UserDao is not known to the MapperRegistry”

  • main-java下创建com-kuang-dao pojo 和utils文件夹 在utils下创建工具类MybaticsUtils
package com.kuang.utils;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.apache.ibatis.session.defaults.DefaultSqlSessionFactory;
import java.io.IOException;
import java.io.InputStream;//sqlSessionFactory ----->sqlSession
public class MybatisUtils {
//提高作用域
private static SqlSessionFactory sqlSessionFactory;
static {try {//使用mybatis第一步 :获取sqlSessionFactory对象String resource = "mybatis-config.xml";InputStream inputStream = Resources.getResourceAsStream(resource);sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);}catch (IOException e) {e.printStackTrace();}
}
//既然有了sqlSessionFactory 顾名思义就可以从中获得sqlsession的实例
//Sqlsession完全包含了面向数据库执行SQL命令所需的所有方法
public static SqlSession getSqlSession() {return sqlSessionFactory.openSession();
}
}
  • 在pojo下创建User 根据数据库创建有参无参 getter/setter toString等

  • 在dao下创建接口UserDao

package com.kuang.dao;
import com.kuang.pojo.User;
import java.util.List;
public interface UserDao {List<User> getUserList();
}
  • 在dao下创建UserMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<!-- namespace 绑定一个对应的Dao/Mapper接口-->
<mapper namespace="com.kuang.dao.UserDao">
<!--select查询语句-->
<select id="getUserList" resultType="com.kuang.pojo.User">select * from mybatis.user
</select>
</mapper>

       resultMap是集合,返回多个 resultType是返回一个。

6)测试(为了工整与创建文件夹一样的格式 )

在这里插入图片描述

  • UserDaoTest里写入
package com.kuang.dao;
import com.kuang.pojo.User;
import com.kuang.utils.MybatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import java.util.List;
public class UserDaoTest {@Testpublic void test(){//第一步 获得sqlsession对象SqlSession sqlSession = MybatisUtils.getSqlSession();//方式一 getMapperUserDao userDao = sqlSession.getMapper(UserDao.class);List<User> userList = userDao.getUserList();for(User user:userList){System.out.println(user);}sqlSession.close();}
}

       可能遇到的问题1:Type interface com.kuang.dao.UserDao is not known to the MapperRegistry
因为没有在核心配置文件中配置mapper

       可能遇到的问题2:maven资源导出失败的问题。在主模块和子模块的pom.xml中写入:

<build><resources><resource><directory>src/main/java</directory><includes><include>**/*.xml</include><include>**/*.properties</include></includes></resource><resource><directory>src/main/resources</directory><includes><include>**/*.xml</include><include>**/*.properties</include></includes></resource></resources>
</build>

       记得刷新maven或者关掉软件再打开。

       可能遇到的问题3:绑定接口错误。

       可能遇到的问题4:返回类型不对。

       可能遇到的问题5:方法名不对。

       可能遇到的问题6:resource路径对应的是/分开。

2. CURD 增删改查

1)nameplace

nameplace中的包名必须和Dao/Mapper接口的包名一致。

2)select

       选择查询语句。

       id:就是对应的nameplace的方法名。

       resultType:sql语句执行的返回值。

       parameterType:参数类型。

3)增删改查过程:

  • 编写接口
//插入一个用户
int addUser(User user);
  • 编写对应的mapper中的sql语句(select/insert/delect/update)
<insert id="addUser" parameterType="com.kuang.pojo.User">insert into mybatis.user(id,name,pwd) values (#{id},#{name},#{pwd});
</insert>
  • 测试
@Test
public void addUser(){SqlSession sqlSession = MybatisUtils.getSqlSession();UserMapper mapper = sqlSession.getMapper(UserMapper.class);int number = mapper.addUser(new User(4,"王先正","123456"));if (number > 0) {System.out.println("插入成功!");}sqlSession.commit();sqlSession.close();
}

       注意: 增删改需要提交事务不然不能改数据库的的内容:sqlSession.commit();

3. 模糊查询

  • java代码执行的时候,传递通配符% _
List<User> userList = mapper.getUserLike("%王%");

       解析:

       中间为王的姓名。

       王% 以王开头的姓名 %王 最后为王的姓名 _是一个字符。

  • 在sql拼接中使用通配符!!!
<select id="getUserLike" resultType="com.kuang.pojo.User">select * from mybatis.user where name like #{value}"%";
</select>

4. 配置解析

4.1 核心配置文件

  • mybatis.config.xml

  • MyBatis 的配置文件包含了会深深影响 MyBatis 行为的设置和属性信息。

  • configuration(配置)

  • properties(属性)

  • settings(设置)

  • typeAliases(类型别名)

  • typeHandlers(类型处理器)

  • objectFactory(对象工厂)

  • plugins(插件)

  • environments(环境配置)
           environment(环境变量)
                  transactionManager(事务管理器)
                  tdataSource(数据源)

  • databaseIdProvider(数据库厂商标识)

  • mappers(映射器)

4.2 环境配置

  • Mybatis可以配置成适应多种环境

  • 尽管可以配置多个环境,但每个sqlsessionfactory实例只能选择一种环境(environments
    中default可以选择相关environment的id)

  • Mybatis默认的事务管理器就是JDBC 连接池是POOLED

  • 学会使用多套运行环境

       注意一些关键点:

  • 默认使用的环境 ID(比如:default=“development”)。

  • 每个 environment 元素定义的环境 ID(比如:id=“development”)。

  • 事务管理器的配置(比如:type=“JDBC”)

  • 数据源的配置(比如:type=“POOLED”)

       默认环境和环境 ID 顾名思义。 环境可以随意命名,但务必保证默认的环境 ID 要匹配其中一个环境 ID。

4.3 属性

  • 这些属性可以在外部进行配置,并可以进行动态替换。你既可以在典型的 Java 属性文件中配置这些属性,也可以在 properties元素的子元素中设置。(db.properties)

  • 在recourse下编写一个配置文件db.properties

driver=com.mysql.jdbc.Driver
url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8
username=root
password=root
  • 再把mybatis-config.xml中改为
<property name="driver" value="${driver}"/>
<property name="url" value="${url}"/>
<property name="username" value="${username}"/>
<property name="password" value="${password}"/>
<!--再引入外部配置文件-->
<properties resource="db.properties"/>

       一定要按规定的顺序写标签

       如果一个属性在不只一个地方进行了配置,那么,MyBatis 将按照下面的顺序来加载:

  • 首先读取在 properties 元素体内指定的属性

  • 然后根据 properties 元素中的 resource 属性读取类路径下属性文件,或根据 url 属性指定的路径读取属性文件,并覆盖之前读取过的同名属性

  • 最后读取作为方法参数传递的属性,并覆盖之前读取过的同名属性

       因此,通过方法参数传递的属性具有最高优先级,resource/url 属性中指定的配置文件次之,最低优先级的则是 properties 元素中指定的属性。(外部引用的)

4.4 类型别名

  • 类型别名可为 Java 类型设置一个缩写名字。 它仅用于 XML 配置,意在降低冗余的全限定类名书写

  • 和propeties标签一样一定要按规则写人

  • typeAlias和package

//为java类型设置一个短名字
<typeAliases>
<typeAlias type="com.kuang.pojo.User" alias="User"/>
//指定一个包名
<package name="com.kuang.pojo" />

       在没有注解的情况下,会使用 Bean 的首字母小写的非限定类名来作为它的别名。

       第一种可以自定义别名 第二种不行,若非要改则需要在实体上增加注解,使用其注解值。

@Alias("hello")
public class User {

       java类型内建的类型别名,不区分大小,采取特殊命名风格:映射类型int–>别名_int 映射类型Integer–>别名int 等。

4.5 设置

       这是 MyBatis 中极为重要的调整设置,它们会改变 MyBatis 的运行时行为。

在这里插入图片描述

4.6 映射器 mappers

       MapperRegistry:注册绑定我们的Mapper文件;

  • 方式一 使用相对于类路径的资源引用 (resour测对应/)推荐使用
<mapper resource="com/kuang/dao/UserMapper.xml"/>
  • 方式二 使用映射器接口实现类的完全限定类名(class对应。)
<mapper class="com.kuang.dao.UserMapper"/>

       注意点:接口和他的Mapper配置文件必须同名!

       接口和他的Mapper配置文件必须在同一个包下。

方式三 使用扫描包进行注入绑定
<package name = "com.kuang.dao">

       注意点和方式二一样!

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

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

相关文章

Python3简单实现与Java的Hutool库SM2的加解密互通

1、背景&#xff1a; 因业务需求&#xff0c;需要与某平台接口对接。平台是Java基于Hutool库实现的SM2加密解密&#xff0c;研究了下SM2的加解密算法&#xff0c;网上找的资料&#xff0c;都是说SM2【椭圆曲线】 公钥长【x,y分量 64字节】&#xff0c;私钥短【32字节】&#x…

华为---OSPF被动接口配置(四)

9.4 OSPF被动接口配置 9.4.1 原理概述 OSPF被动接口也称抑制接口&#xff0c;成为被动接口后&#xff0c;将不会接收和发送OSPF报文。如果要使OSPF路由信息不被某一网络中的路由器获得且使本地路由器不接收网络中其他路由器发布的路由更新信息&#xff0c;即已运行在OSPF协议…

FuTalk设计周刊-Vol.031

&#x1f525;AI漫谈 热点捕手 1、如何用自然语言 5 分钟构建个人知识库应用&#xff1f;我的 GPTs builder 尝试 开发者的想象力闸门一旦打开&#xff0c;迎接我们的必然是目不暇接的 AI 应用浪潮冲击。 链接https://sspai.com/post/84325 2、GPT-4 Turbo、功能融合&#x…

【机器学习】大模型驱动下的医疗诊断应用

摘要&#xff1a; 随着科技的不断发展&#xff0c;机器学习在医疗领域的应用日益广泛。特别是在大模型的驱动下&#xff0c;机器学习为医疗诊断带来了革命性的变化。本文详细探讨了机器学习在医疗诊断中的应用&#xff0c;包括疾病预测、图像识别、基因分析等方面&#xff0c;并…

LCR 142.训练计划IV

1.题目要求: /*** Definition for singly-linked list.* struct ListNode {* int val;* struct ListNode *next;* };*/ int compare(const void* a,const void* b) {return (*(int*)a - *(int*)b); } struct ListNode* trainningPlan(struct ListNode* l1, struct Li…

【数据结构】第十九弹---C语言实现冒泡排序算法

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】 目录 1、冒泡排序基本思想 2、代码的初步实现 3、代码的优化 4、代码的测试 5、时空复杂度分析 6、模拟实现qsort 6.1、冒泡排序函数 6.2、交换数…

针对 AI 优化数据湖仓一体:使用 MinIO 仔细了解 RisingWave

RisingWave 是现代数据湖仓一体处理层中的开源流数据库&#xff0c;专为性能和可扩展性而构建。RisingWave 旨在允许开发人员在流数据上运行 SQL。鉴于 SQL 是数据工程的通用语言&#xff0c;此功能非常重要。它具有强大的架构&#xff0c;包括计算节点、元节点和压缩器节点&am…

分享一个 Fail2ban 过滤规则

今天明月给大家分享个 Fail2ban 的过滤&#xff08;Filter&#xff09;规则&#xff0c;有关 Fail2ban 的文章大家可以参考【服务器全面使用 Fail2Ban 初见成效】和【使用 Fail2ban 禁止垃圾采集爬虫&#xff0c;保护 Nginx 服务器】等文了解&#xff0c;总之 Fail2ban 是 Linu…

分流井设备的监测控制和智慧运维

分流井是一种用于将雨水和污水进行分离的设施&#xff0c;通常设置在雨水管和污水管的汇合处。它可以根据不同的情况&#xff0c;将雨水和污水分别排放到不同的管道中&#xff0c;从而实现雨污分流的目的。 以下是一些常见的分流井类型和工作原理&#xff1a; 1、智能分流井&a…

java-SpringBoot执行定时任务-任务调度-@EnableScheduling和@Scheduled

文章目录 java借助springBoot框架&#xff0c;执行定时任务0. 项目地址1. 需求分析2、新建springBoot项目3. 编写定时任务3.1 开启调度任务3.2 编写定时任务方法 java借助springBoot框架&#xff0c;执行定时任务 0. 项目地址 https://github.com/OrangeHza/JavaDemo 1. 需求…

Redis小对象压缩

小对象压缩存储 如果Redis内部管理的集合数据结构很小&#xff0c;他会使用紧凑存储形式压缩存储。 Redis的ziplist是一个紧凑的字节数组结构&#xff0c;如下图所示&#xff0c;每个元素之间都是紧挨着的。 如果他存储的是hash结构&#xff0c;那么key和value会作为两个ent…

竞赛 机器视觉的试卷批改系统 - opencv python 视觉识别

文章目录 0 简介1 项目背景2 项目目的3 系统设计3.1 目标对象3.2 系统架构3.3 软件设计方案 4 图像预处理4.1 灰度二值化4.2 形态学处理4.3 算式提取4.4 倾斜校正4.5 字符分割 5 字符识别5.1 支持向量机原理5.2 基于SVM的字符识别5.3 SVM算法实现 6 算法测试7 系统实现8 最后 0…

Maven添加reactor依赖失败

目录 情况说明 解决过程 情况说明 起初是自己在学spring boot3&#xff0c;结果到了reactor这一部分的时候&#xff0c;在项目的pom.xml文件中添加下列依赖报错&#xff1a; <dependencyManagement><dependencies><dependency><groupId>io.projectr…

【CPP】插入排序、希尔排序

目录 1.插入排序1.1直接插入排序简介代码分析 1.2直接插入对比冒泡排序简介代码对比分析(直接插入排序与冒泡的复杂度效率区别) 1.3希尔排序简介代码分析 1.插入排序 基本思想&#xff1a;把一个待排数字按照关键码值插入到一个有序序列中&#xff0c;得到一个新的有序序列。 …

前沿技术丨S2S自动化测试解决方案

技术背景 随着面向服务的架构&#xff08;Service-Oriented Architecture&#xff0c;SOA&#xff09;在整车架构中的逐步推进及应用&#xff0c;车内网络通信中会一直并存基于以太网的面向服务和基于传统网络的面向信号的两类控制器&#xff0c;S2S&#xff08;Signal to Ser…

AXI学习笔记

文章目录 AXI口诀&#xff1a;AXI三种总线&#xff0c;三种接口&#xff0c;一个协议背景知识一、 AMBA&#xff1a;二、AXI2.1 通信协议与握手机制2.2 AXI协议特点2.3 三种AXI总线类型&#xff08;AXI4、AXI4-lite、AXI4-stream&#xff09;2.3.1 AXI通道&#xff08;5通道&am…

GD32 MCU的选项字节是什么?

GD32 MCU的选项字节是什么&#xff0c;有什么功能呢&#xff1f;选项字节被误篡改如何回复&#xff1f; 读者朋友们是否会有以上的疑问&#xff0c;首先我们先为大家介绍选项字节是什么以及选项字节的功能。 以GD32F30X系列MCU为例&#xff0c;其选项字节说明如下表所示&…

力扣每日一题 6/22 字符串/贪心

博客主页&#xff1a;誓则盟约系列专栏&#xff1a;IT竞赛 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 2663.字典序最小的美丽字符串【困难】 题目&#xff1a; 如果一个字符串满…

2024年7月JLPT日语N1真题试卷和答案解析,《Navi日语社》小程序在线答题考试,你的专属考试助手,日语学习神器!

掌握日语&#xff0c;从日语社小程序开始。这款小程序专为日语学习者设计&#xff0c;提供全面的JLPT备考资源&#xff0c;包括日语N1至N5等级考试的历年真题和2024年最新题目。无论你是日语新手还是备考高手&#xff0c;都能在这里找到适合自己的学习路径。 核心功能&#xf…

uniapp 打包 H5 实现在 uniapp 打包 APP 的 webview 通信

一、前言 遇到 uniapp 打包的 APP 在 webview 内嵌入 uniapp 打包的 H5 页面的需求&#xff0c;并实现通信。本篇主要总结了如何实现并总结遇到的问题&#xff0c;希望可以帮助大家减少负担。 实现需求主要有三个地方需要处理&#xff1a; index.html 的打包配置导入 uni.we…