【MyBatis 学习三】子段不一致问题 多表查询 动态SQL
目录
一、解决Java实体类属性与数据库表字段不一致问题
🌷现象1:显示字段不对应:使用ResultType查询结果为null;
🌷解决办法:字段不对应:使用ResultMap解决。
二、数据库的多表查询
🌷方式1:使用对象user
🌷方式2:直接写具体的属性
三、动态SQL的使用
🌷1、if标签:单个参数不确定
🌷2、trim标签:多个参数不确定,搭配if标签一起使用
🌷3、where标签:搭配if标签
方式1:使用where关键字(注意不是where标签)
方式2:使用标签
🌷4、set标签:搭配if标签
🌷5、foreach标签:用于批量操作,搭配if\where标签
🍉个人小结
一、解决Java实体类属性与数据库表字段不一致问题
在对数据进行增删改查的时候,如果是增,删,改一般会返回受影响的行数,所以在mapper.xml文件中可以不设置返回的类型;但是对于查询,无论查询什么内容,都要设置返回的数据类型。如下:
查询:
增加、删除和修改:一般可以不设置返回类型:
所以对于<select>查询标签来说,至少需要两个属性
(1)i属性:用于标识实现接口中的哪个方法;
(2)结果映射属性:有两种实现标签:<resultType>和<resultMap>
其中,在前一节我们定义用户实体类的时候,强调了当时的属性名要与数据库中表的字段名一致,就可以使用<resultType>了。但是在实际开发中,Java中的实体类属性一般是小驼峰命名,数据库中的字段属性是字母小写并用下划线分隔,两者之间的名称可能不一致,那么此时就要用到<resultMap>了。
🌷现象1:显示字段不对应:使用ResultType查询结果为null;
xml文件
结果:
🌷解决办法:字段不对应:使用ResultMap解决。
UserMapper.xml文件
<resultMap id="BaseMap1" type="demo3.model.User"><id property="id" column="id"></id><result property="name" column="username"></result><result property="pwd" column="password"></result><result property="photo" column="photo"></result><result property="createTime" column="createTime"></result><result property="updateTime" column="updateTime"></result><result property="state" column="state"></result></resultMap><select id="queryAllByMap" resultMap="BaseMap1">select * from userinfo</select>
结果:
注意点:
一个xml文件中可以有多个resultMap,只要Id不同就行。(我们这里是所有的字段都写了)实际没写的字段,会按照默认的规则来帮助我们映射:当数据库字段和Java属性字段一直的话,就会自动映射。通常情况下,如果我们写了ResultMap,不论是否一致,都将属性写全。
二、数据库的多表查询
有两张表:
数据库中的左连接操作:根据文章表中的用户id查找对应的用户表的用户信息,写法如下:我们现在就实现这个功能:
🌷方式1:使用对象user
创建两个类:User类和Article类
注意点1:这里设置文章表的属性的时候,设置一个user对象。
UserMapper与ArticleMapper
xml文件
注意点2:在ArticleMapper.xml文件中设置user的时候,要用association引入UserMapper的ResultMap的路径:路径名是UserMapper的namespace名+ResultMap的id名称。
测试类:
测试结果:
注意点3:可以看到在文章表中查询出来的结果,其中的用户信息是一个user对象来表示的。
🌷方式2:直接写具体的属性
注意1:这里的文章类:我们就不定义user对象了,而是要查询用户的Id和用户名,我们就将这两个字段定义出来。
注意点2:xml文件中也是直接通过resutMap的result定义出用户的Id和用户名,不用再引入UserMapper.xml文件中的ResultMap了。
结果:
注意点3:可以看到最终查询的结果也是具体的用户Id和用户名信息,而不是方式1的整个user对象。
三、动态SQL的使用
动态SQL:根据输入参数的不同,动态的拼接SQL,从而完成不同条件下的SQL拼接。
比如在实际场景下,有时候我们进行注册,有的字段是必填的,有的又不是必填的,如果在注册用户的时候有不确定的字段传入,那么怎么实现呢?
🌷1、if标签:单个参数不确定
<insert id="insertByIf">insert into articleInfo ( title,content,uid <if test="state!=null">,state</if>)values ( #{title},#{content},#{uid} <if test="state!=null">,#{state}</if>)</insert>
(1)用法
测试结果1:当输入state状态:
测试情况2:不输入state
注意:if标签里面的属性是Java对象的属性字段state,而不是数据库表中的字段。而insert中的sql语句的字段是数据库表中的字段,注意区分~
(2)存在问题
当我多个参数都不确定的时候,写成id标签的形式,会导致逗号放在哪里都存在问题。
如果统一将逗号放在字段前面,当第一个字段为null的时候,整个SQL最前面就会多一个逗号;如果统一将逗号放在字段后面,当最后一个字段为null的时候,整个SQL最后面就会多一个逗号,所以这个时候我们就要用<trim>标签结合<if>标签,对多个字段都采取动态⽣成的⽅式了。
🌷2、trim标签:多个参数不确定,搭配if标签一起使用
<trim>标签中有如下属性:
- prefix:表示整个语句块,以prefix的值作为前缀:表示从(开始
- suffix:表示整个语句块,以suffix的值作为后缀:表示从 )结束
- prefixOverrides:表示整个语句块要去除掉的前缀:表示去掉左边的逗号
- suffixOverrides:表示整个语句块要去除掉的后缀:表示去掉右边的逗号
<insert id="insertByIf">insert into articleInfo<trim prefix="(" suffix=")" prefixOverrides="," suffixOverrides=","><if test="title!=null">title,</if><if test="content!=null">content,</if><if test="uid!=null">uid,</if><if test="state!=null">state</if></trim>values<trim prefix="(" suffix=")" prefixOverrides="," suffixOverrides=","><if test="title!=null">#{title},</if><if test="content!=null">#{content},</if><if test="uid!=null">#{uid},</if><if test="state!=null">#{state}</if></trim></insert>
在以上 sql 动态解析时,会将第⼀个 <trim> 部分做如下处理:
(1)基于 prefix 配置,开始部分加上 (
(2)基于 suffix 配置,结束部分加上 )
(3)多个 <if>组织的语句都以 , 结尾,在最后拼接好的字符串还会以 , 结尾,会基于 suffixO
verrides 配置去掉最后⼀个 ,
(4)注意 <if test=“state!= null”> 中的 state是传⼊对象的属性;测试:当不传入state的时候:
🌷3、where标签:搭配if标签
方式1:使用where关键字(注意不是where标签)
当uid为null的时候:
当state为null的时候:
当uid和state为null的时候:
方式2:使用<where>标签
当uid为null的时候:
当state为null的时候
当两个都为null的时候:
从上述案例中可以看出where标签的作用:
(1)生成where关键字;
(2)去掉多余的and;
(3)如果没有where条件,就不会生成where关键字
🌷4、set标签:搭配if标签
当只设置uid值的时候,测试通过(同样其他情况也是测试通过的。)
set作用:
(1)set标签生成set关键字;
(2)去除最后一个逗号。
🌷5、foreach标签:用于批量操作,搭配if\where标签
批量操作:插入、删除、更新等。演示批量删除:
- collection:绑定⽅法参数中的集合,如 List,Set,Map或数组对象;
- item:遍历时的每⼀个对象
- open:语句块开头的字符串
- close:语句块结束的字符串
- separator:每次遍历之间间隔的字符串。
注意:collection中除了可以写Llist,还可以写参数名称,此时对参数进行重命名:
🍉个人小结:
1、字段名称和程序中的属性名不同的情况,可使⽤ resultMap 配置映射。
2、多表查询:文章表中有用户Id和用户名,要通过文章表查询用户信息:有两种方式:
(1)在文章实体类定义属性为user,则文章表的xml文件中要通过association引入用户user的ResultMap的地址;
(2)直接在文章的实体类中定义属性用户Id和用户名,此时文章表中的xml文件通过resultMap引入这两个属性。
3、动态SQL:
(1)<if>标签是基础,后面的<trim>标签、<where>、<set>、<foreach>标签都是结合if标签使用的。
(2)当只有单个参数不确定的时候,使用If标签;
(3)当多个参数不确定,要trim标签;
(4)条件不确定的时候用where标签:也可以用where关键字加一个条件1=1;
(5)set标签设置 不确定的属性;
(6)foreach标签批量处理数据:插入、删除修改等。collection中传入list等;当对接口方法中的参数重命名后,collection也可以使用参数的名称。😁
相关文章:

【MyBatis 学习三】子段不一致问题 多表查询 动态SQL
目录 一、解决Java实体类属性与数据库表字段不一致问题 🌷现象1:显示字段不对应:使用ResultType查询结果为null; 🌷解决办法:字段不对应:使用ResultMap解决。 二、数据库的多表查询 &#…...

15. Spring AOP 的实现原理 代理模式
目录 1. 代理模式 2. 静态代理 3. 动态代理 3.1 JDK 动态代理 3.2 CGLIB 动态代理 4. JDK 动态代理和 CGLIB 动态代理对比 5. Spring代理选择 6. Spring AOP 实现原理 6.1 织入 7. JDK 动态代理实现 8. CGLIB 动态代理实现 9. 总结 1. 代理模式 代理模式…...

死锁产生的原因以及解决方案
一.原因: 1.使用互斥锁. 2.除非主动释放,负责不能被抢占. 3.占用一把锁不释放,等待其它锁资源(保持现状). 4.锁形成环路. 二.解决方案: 给锁编号,上锁的时候从小到大依次上锁,譬如如果一个线程要上1号和2号两把锁,如果1号锁被占用,不能上2号锁,等其它线程释放1号锁资源后…...

【构造】CF1758 D
Problem - D - Codeforces 题意: 思路: 如果需要构造一个和为定值的序列,那么考虑n-d,n-d1,.....nd-1,nd这种形式 如果要保证不能重复,那么先考虑一个排列,然后在排列上操作 如果根据小数据构造出了一些简单情形&a…...

【腾讯云 Cloud Studio 实战训练营】永不宕机的IDE,Coding Everywhere
【腾讯云 Cloud Studio 实战训练营】永不宕机的IDE,随时随地写代码! 写在最前视频讲解:Cloud Studio活动简介何为腾讯云 Cloud Studio?Cloud Studio简介免费试用,上手无忧Cloud Studio 特点及优势云端开发多种预制环境可选metawo…...

JavaScript将一层级对象数组转为children嵌套的三层级树状对象数组(多级树状分类)
有时候后端返回的数据不适合前端,我们就需要进行转换,比如我想用elementUI的级联选择器,而这个组件对数据格式有要求,本篇文章将介绍如何将一层级对象数组数据格式转为三层级嵌套children数组,JavaScript、Vue、小程序等都适用,使用情景为多级分类,嵌套数据 情况1:原数…...

Windows脚本启动Redis、Java和Nginx服务指南
文章目录 1. 完整的批处理脚本2. Redis服务3. Java服务4. Nginx服务 1. 完整的批处理脚本 echo offcd C:\path\to\redis tasklist /FI "IMAGENAME eq redis-server.exe" 2>NUL | find /I /N "redis-server.exe">NUL if "%ERRORLEVEL%"&qu…...

【宝藏系列】STM32之C语言基础知识
【宝藏系列】STM32之C语言基础知识 文章目录 【宝藏系列】STM32之C语言基础知识1️⃣位操作2️⃣define宏定义3️⃣ifdef条件编译4️⃣extern变量声明5️⃣typedef类型别名 C语言是单片机开发中的必备基础知识,本文列举了部分 STM32 学习中比较常见的一些C语言基础知…...

探索自除数:发现区间内的神奇数字
本篇博客会讲解力扣“728. 自除数”的解题思路,这是题目链接。 对于给定的正整数num,我们如何判断它是不是自除数呢?根据定义,我们只需要把num的每一位数字都取出来,判断能不能整除num,如果发现num的某一位…...

打卡力扣题目四
#左耳听风 ARST 打卡活动重启# 目录 一、题目 二、解题代码 三、解题思路 关于 ARTS 的释义 —— 每周完成一个 ARTS: ● Algorithm: 每周至少做一个 LeetCode 的算法题 ● Review: 阅读并点评至少一篇英文技术文章 ● Tips: 学习至少一个技术技巧 ● Share: 分享…...

npm yarn nrm
npm 和 yarn npm和yarn都是包管理器,yarn是在2016年发布的,那时npm还处于V3时期,那时候还没有package-lock.json文件,不稳定性、安装速度慢等缺点经常会受到广大开发者吐槽。此时,yarn 诞生了。yarn 的优点,…...

关于我对刚开始学Java的小白想分享的内容:
编程是很有魅力的,让很多人为之痴迷 如果你是初学者,俗称小白,不妨看看下述内容: 文章目录 1. Java 简介 Java 是一门编程语言,发展至今已经成为一门真正意义上的语言标准。 Java是一个完整的平台,有一个…...

Redis学习路线(5)—— Redis生成唯一ID
一、全局唯一ID (一)在用户抢购时,就会生成订单并保存到数据库中,而订单表如果使用自增ID就会存在以下几种情况: 自增ID规律性太强受单表数据量的限制 (二)全局ID生成器,是一种在…...

django后台系统Tyadmin
无意之间发现个django的后台管理框架,仔细与xadmin对比了一下,无论是功能上还是便携性上都与xadmin特别相似,但个人感觉Tyadmin略胜一筹,因为外观上要比xadmin要美观,而且相比起来速度也快,部署甚至也和简单…...

设计模式适合用于解决特定的软件设计问题呢
当我们在开发软件时,经常会遇到各种各样的问题和挑战,例如如何处理对象之间的关系、如何实现复杂的业务逻辑、如何处理并发访问等。这些问题都是软件设计中经常遇到的问题,而设计模式就是为了解决这些问题而诞生的。 以下是一些常见的软件设…...

测试|测试分类
测试|测试分类 文章目录 测试|测试分类1.按照测试对象分类(部分掌握)2.是否查看代码:黑盒、白盒灰盒测试3.按开发阶段分:单元、集成、系统及验收测试4.按实施组织分:α、β、第三方测试5.按是否运行代码:静…...

矩阵中的路径(JS)
矩阵中的路径 题目 给定一个 m x n 二维字符网格 board 和一个字符串单词 word 。如果 word 存在于网格中,返回 true ;否则,返回 false 。 单词必须按照字母顺序,通过相邻的单元格内的字母构成,其中“相邻”单元格是…...

Linux时间体系与LinuxPTP
Linux时间体系 Linux 需要提供“知道当前时间、计算时间长度、定时提醒”这三种功能。 其中知道当前时间和计算时间长度在某种程度上可以互相转换。即以UNIX Epoch计时开始可以知道当前时间。 一般硬件可以提供下列的硬件时钟: RTC 【真实时钟】 对于PC而言&…...

最优除法(力扣)数学 JAVA
给定一正整数数组 nums,nums 中的相邻整数将进行浮点除法。例如, [2,3,4] -> 2 / 3 / 4 。 例如,nums [2,3,4],我们将求表达式的值 “2/3/4”。 但是,你可以在任意位置添加任意数目的括号,来改变算数的…...

Git代码管理
目录: git环境配置 git工作流程git常用命令gitlab实战gitlog分析与检索分支管理策略git合并与冲突 1.git环境配置 Git 简介: Git 是目前世界上最先进的分布式版本控制系统。Git 优点: 适合分布式开发,强调个体…...

使用vscode进行远程开发服务器配置
1.下载vscode 2.给vscode 安装python 和 remote ssh插件 remote—SSH扩展允许您使用任何具有SSH服务器的远程机器作为您的开发环境。 3.安装remote-SSH插件之后,vscode左侧出现电脑图标,即为远程服务,按图依次点击,进行服务器配置…...

北斗gps卫星授时服务器(NTP)应用于防火墙场景
北斗gps卫星授时服务器(NTP)应用于防火墙场景 北斗gps卫星授时服务器(NTP)应用于防火墙场景 作为网络建设中不可或缺的两方面,在保证网络安全稳定以及时间同步精确性方面,防火墙和NTP服务器都极为重要。而防…...

Quartz中Misfire机制源码级解析
文章目录 前文案例展示Misfire机制1. 启动过程补偿2. 定时任务补偿3. 查询待触发列表时间区间补偿 前文 Misfire是啥意义的?使用翻译软件结果是"失火"。一个定时软件,还来失火?其实在Java里面,fire的含义更应该是触发&…...

每日一题——重建二叉树
重建二叉树 题目描述 给定节点数为 n 的二叉树的前序遍历和中序遍历结果,请重建出该二叉树并返回它的头结点。 例如输入前序遍历序列{1,2,4,7,3,5,6,8}和中序遍历序列{4,7,2,1,5,3,8,6},则重建出如下图所示。 提示: 1.vin.length pre.length 2.pre 和…...

Python - json与字典dict
Python中的JSON和字典都是数据序列化的格式,它们都可以将数据转换为字符串以便于存储或传输。虽然它们有一些相似之处,但也有很多不同之处。 字典 字典是Python中的一种数据类型,它是一个键值对的集合。每个键对应一个值,可以通…...

性能测试必备监控技能linux篇
前言 如果性能测试的目标服务器是linux系统,在如何使用linux自带的命令来实现性能测试过程的监控分析呢? 对于日常性能测试来讲,在linux下或是类Unix系统,我们必须掌握以下常用的指标查看命令。 ps pstree top free vmstat …...

【如何训练一个中英翻译模型】LSTM机器翻译模型部署之ncnn(python)(五)
系列文章 【如何训练一个中英翻译模型】LSTM机器翻译seq2seq字符编码(一) 【如何训练一个中英翻译模型】LSTM机器翻译模型训练与保存(二) 【如何训练一个中英翻译模型】LSTM机器翻译模型部署(三) 【如何训练…...

C++ 面向对象三大特征
文章目录 一、封装二、继承三、多态 一、封装 目的:隐藏实现细节;模块化 特性: 1) 访问权限: public 所有 protected 子类 private 自己(友元类也可以访问) 2)属性 3)方…...

【Github】自动监测 SSL 证书过期的轻量级监控方案 - Domain Admin
在现代的企业网络中,网站安全和可靠性是至关重要的。一个不注意的SSL证书过期可能导致网站出现问题,给公司业务带来严重的影响。针对这个问题,手动检测每个域名和机器的证书状态需要花费大量的时间和精力。为了解决这个问题,我想向…...

Echarts常见图表展示
一、折线图 1.1 堆叠折线图 const option {title: {text: 折线图,},tooltip: {trigger: axis},legend: {data: [张三, 李四, 王五],bottom: 10,},grid: {left: 3%,right: 4%,bottom: 10%,containLabel: true},xAxis: {type: category,boundaryGap: false,data: [Mon, Tue, We…...