mybatis 一对一 一对多 级联查询

大家好,我是烤鸭:

    今天分享一下关于mybatis的级联查询。

    环境:

        mybatis   3.2.8

        spring      4.1.9

 

1.   业务场景

    在一个人申请某些账号或者权限的时候,比如微信的认证流程。

   会让你一步一步按要求输入,比如第一步:点击微信认证,第二步:认证联系人信息填写;最后一步:填写公众号名称、功能介绍、选择运营地区就。

   当你在填写完第二步退出之后,再重新登录会发现第一步的信息已经记录了。

   这里至少要设计四张表,流程表和每一步的表,都是主键一一关联,这是一对一。

   又或者如其他平台的企业版的认证,可以添加下级的机构,这就是一对多了。

2.    mybatis 构建

     get,set方法是必须要的,我这里没粘贴出来。

pojo:

public class ApplyCompanyBackResp{private static final long serialVersionUID = 1L;private ApplyCompanyBusinessA businessA1;private ApplyCompanyBusinessAl businessAl;private ApplyCompanyBusinessCt businessC1;private ApplyCompanyBusinessCr businessC2;private ApplyCompanyBusinessJ businessAliantJ1;private ApplyCompanyBusinessM businessM1;private ApplyCompanyBusinessMo businessAliantM2;private List<ApplyCompanyBusinessJ1Store> businessJ1StoreList;}

mapper:

<!--根据当前页面获取该企业开通的权限--><select id="applyCompanyAuthorityBusiness" parameterType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyAuthority"resultMap="applyCompanyResp">SELECTacbc.`status` AS 'c1Status','c1' AS 'c1Remarks',acbcc.`status` AS 'c2Status','c2' AS 'c2Remarks',acba.`status` AS 'a1Status','a1' AS 'a1Remarks',acbac.`status` AS 'a2Status','a2' AS 'a2Remarks',acbj.status AS 'J1Status','j1' AS 'j1Remarks',acbmr.`status` AS 'm1Status','m1' AS 'm1Remarks',acbmr2.status AS 'm2Status','m2' AS 'm2Remarks',acbjs.jx_name AS 'j1Name',acbjs.status AS 'j1StoreStatus'FROM apply_company_process acpLEFT JOIN apply_company_business_c1 acbc ON acbc.apply_id = acp.apply_idLEFT JOIN apply_company_business_c2 acbcc ON acbcc.apply_id = acp.apply_idLEFT JOIN apply_company_business_a1 acba ON acba.apply_id = acp.apply_idLEFT JOIN apply_company_business_a2 acbac ON acbac.apply_id = acp.apply_idLEFT JOIN apply_company_business_j1 acbj ON acbj.apply_id = acp.apply_idLEFT JOIN apply_company_business_m1 acbmr ON acbmr.apply_id = acp.apply_idLEFT JOIN apply_company_business_m2 acbmr2 ON acbmr2.apply_id = acp.apply_idLEFT JOIN apply_company_business_j1_store acbjs ON acbjs.apply_id = acbj.apply_id<where>1 = 1 AND 'needOptimization' = 'needOptimization' AND acp.apply_id = #{applyId}</where></select><resultMap type="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBackResp" id="applyCompanyResp"><!-- 配置xx相关的映射信息 --><association property="businessA1" column="apply_id" javaType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBusinessA1"><id  property="applyId" column="applyId" /><result property="remarks" column="a1Remarks"/><result property="status" column="a1Status"/></association><!-- 配置xx的映射信息 --><association property="businessA2" column="apply_id" javaType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBusinessA2"><id  property="applyId" column="applyId" /><result property="remarks" column="a2Remarks"/><result property="status" column="a2Status"/></association><!-- 配置xx相关的映射信息 --><association property="businessC1" column="apply_id" javaType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBusinessC1"><id  property="applyId" column="applyId" /><result property="remarks" column="c1Remarks"/><result property="status" column="c1Status"/></association><!-- 配置xx相关的映射信息 --><association property="businessC2" column="apply_id" javaType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBusinessC2"><id  property="applyId" column="applyId" /><result property="remarks" column="c2Remarks"/><result property="status" column="c2Status"/></association><!-- 配置xx相关的映射信息 --><association property="businessAliantJ1" column="apply_id" javaType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBusinessJ1"><id  property="applyId" column="applyId" /><result property="remarks" column="j1Remarks"/><result property="status" column="j1Status"/></association><!-- 配置xx相关的映射信息 --><association property="businessM1" column="businessMobileRecycling.aliStatus" javaType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBusinessM1"><id  property="applyId" column="applyId" /><result property="remarks" column="m1Remarks"/><result property="status" column="m1Status"/></association><!-- 配置xx相关的映射信息 --><association property="businessAliantM2" column="apply_id" javaType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBusinessM2"><id  property="applyId" column="applyId" /><result property="remarks" column="m2Remarks"/><result property="status" column="m2Status"/></association><!-- 配置xx相关的信息 --><!--collection用于指定集合类型的映射.property指定对应的集合名称.ofType指定集合中存放的数据的类型  --><collection property="businessJ1StoreList" ofType="com.xxx.xxxx.xxx.xxx.xxx.entity.ApplyCompanyBusinessJ1Store"><!-- id和result指定了需要配置的列和属性名和映射 --><result property="applyId" column="applyId" /><result property="jxName" column="j1Name"/><result property="status" column="j1StoreStatus"/></collection></resultMap>

从sql我们可以看出来,有一张process主表,其他的表都是以applyId作为主键关联。其中store表是一对多的关系,其他都是一对一。如果我们想把这个企业的所有权限信息展示,就需要关联这些所有的表。

需求是查询这些权限的状态,所以不需要太多其他的字段。

association  一对一。

property :

association  中的 property 对应的是 resultMap实体中的属性名称,在上面就是这个ApplyCompanyBackResp。

ApplyCompanyBackResp 这个pojo中的属性名称,比如 businessA1 对应的 property 就是 businessA1。

column:

column 是一定要写的 ,对应的是数据库的关联字段名称,比如上边的是apply_id 。

javaType:

返回的实体类型。

id:

数据库表主键,我这边是主键关联,所以id就是apply_id。property 是 实体属性 ,column是 查询的结果字段(别名)。比如上边的各种status,是起的别名,这里要和下边的 column 对应上。

针对于我这边不需要查询主键,可以不查。

result:

和id是一样的, 是非主键的字段映射。property 是 实体属性 ,column是 查询的结果字段(别名)。

 

collection 一对多:

property :

association  中的 property 对应的是 resultMap实体中的属性名称,在上面就是这个ApplyCompanyBackResp。

ApplyCompanyBackResp 这个pojo中的属性名称,比如 businessJ1StoreList对应的 property 就是 businessJ1StoreList。

ofType:

返回的实体类型。

id:

数据库表主键,我这边是主键关联,所以id就是apply_id。property 是 实体属性 ,column是 查询的结果字段(别名)。比如上边的各种status,是起的别名,这里要和下边的 column 对应上。

针对于我这边不需要查询主键,可以不查。

result:

和id是一样的, 是非主键的字段映射。property 是 实体属性 ,column是 查询的结果字段(别名)。

 

3.    总结

    mybatis的级联查询,如果是一对一,一定在 association标签内加 column属性。这样查询出来的才能封装到 结果对象 中。

    如果是一对多,mysql查询出来的数据结果就会是多条。比如上面的情况,查询出来的结果如果是2条,这两条数据collection前面的结果是一样的,只是针对于collection中的属性名称的 结果 不一样。类似下图,应该j1Name,j1StoreStatus 这列是从别的表查询出来的,其他列数据是相同的。

    如果你想清晰一点你的话,也可以在 association 或者 collection 写 select标签,值是 select 语句。类似下图

    

 

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

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

相关文章

IDEA启动tomcat报错java.util.zip.ZipException: error in opening zip file

原因CATALINA_BASE参数后面多了一个斜杠 将&#xff1a;CATALINA_BASEK:\Tomcats\apache-tomcat-9.0.10_cform\ 改&#xff1a;CATALINA_BASEK:\Tomcats\apache-tomcat-9.0.10_cform

java 实现 常见排序算法(二) 插入排序

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享一下基础排序算法之直接插入排序。 1. 直接插入排序&#xff1a; 原理&#xff1a;假设前面的数为有序数列&#xff0c;然后有序数列与无序数列的每个数比较&#xff0c;我们可以从右向左比较 思路&#xff1a;从第2…

linux 常用 启动命令 汇总

大家好&#xff0c;我是烤鸭&#xff1a; 没有准备启动脚本。服务器出问题之后&#xff0c;重启就是全部重启。 如&#xff1a; mysql,nginx,tomcat,zookeeper,rabbitmq,mongodb,redis,xxxxx 头大。持续更新。。。 consul启动&#xff1a; (公网可以访问 使用-client 0.0.0…

java 爬虫 抓取 网易云音乐

大家好&#xff0c;我是烤鸭&#xff1a; 今天和大家交流一下爬虫&#xff0c;抓取网易云音乐。只讨论技术&#xff0c;不提倡其他的。 1. 找音乐源地址 谷歌浏览器 F12 &#xff0c;找请求类型是 Media的。 2. 找请求链接 切换请求类型到 All&#xff0c;看 Respons…

idea警告Cannot resolve MVC View

关闭MVC View路径检查,Settings --> Editor -->Inspections -->搜索Spring MVC View—>取消勾选Spring MVC View Reference

ssh sftp 免密码 公钥登录

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享的是java ssh sftp 免密码登录。 1. JAVA代码 ssh连接 http://www.360doc.com/content/14/0409/16/9552892_367544139.shtml https://blog.csdn.net/u013066244/article/details/70198839 公钥和私钥不需要用代码生成&…

CF989E A Trance of Nightfall(概率+矩阵快速幂优化+倍增)

CF传送门 洛谷传送门 【题目分析】 在zxy大佬的讲解下终于懂了这道题的做法了qwq。。。 首先根据题意&#xff0c;出发点不一定在特殊点上&#xff0c;但第一次操作后&#xff0c;之后所有的操作都是在特殊点上&#xff0c;所以先考虑从线上出发的最大概率&#xff0c;再加一步…

SqlServer自定义聚合函数

sqlserver2017版本包括以上的可以使用string_agg(字段,’,’)函数 sqlserver查询版本&#xff1a; select versionSql Server自定义聚合函数详细bai步骤 开始-> 输出-> 首先用baiVS2008/VS2005建立一个SQL Server项目&#xff0c;右键解决方案添加新项 点击“确定…

springboot : Failed to decode downloaded font 和 OTS parsing error

大家好&#xff0c;我是烤鸭&#xff1a; 采坑实录&#xff0c;看了很多人跟我有类似问题&#xff0c;但是都没解决我的问题&#xff1a; Failed to decode downloaded font 和 OTS parsing error: 尝试了把woff文件移动到其他可以加载的静态资源文件夹下&#xff0c;还是无法…

【objectMapper实体转换异常】 com.fasterxml.jackson.databind.exc.MismatchedInputException

大家好&#xff0c;我是烤鸭&#xff1a; 采坑实录&#xff0c;想把json数据直接转成对象&#xff0c;其中有个属性是list<T>&#xff1a; 异常 1 com.fasterxml.jackson.databind.exc.MismatchedInputException: Cannot deserialize instance of java.util.ArrayList o…

java 实现 常见排序算法(三)快速排序

大家好&#xff0c;我是烤鸭&#xff1a; 今天分享一下基础排序算法之快速排序。快速排序是内部排序&#xff08;基于比较排序&#xff09;中最好的比较算法。 1. 快速排序&#xff1a; 原理&#xff1a;在要排的数&#xff08;比如数组A&#xff09;中选择一个中心值k…

解决org.apache.hadoop.io.nativeio.NativeIOException: 当文件已存在时,无法创建该文件。

Hadoop在本地运行的时候总是出现这个异常&#xff0c;虽然这个异常不影响代码运行&#xff0c;但是看着很不爽 1&#xff0c;找到log4j.properties文件&#xff0c;查看log4j.rootLogger&#xff0c;但是却没有debug log4j.rootLogger info,stdout2&#xff0c;查看pom.xm…

springboot websocket

大家好&#xff0c;我是烤鸭&#xff1a; 今天想分享一下springbootwebsocket。 之前接到一个需求&#xff0c;需要在页面监听后台的数据&#xff08;输入邮箱后&#xff0c;需要用户打开邮箱&#xff0c;页面监听用户是否点击激活邮件&#xff09;。之前的实现方式&#xff0c…

idea的plugins无法使用marketplace plugins are not loaded

idea64.exe.vmoptions删除-Djsse.enableSNIExtensionfalse 再次重启后就可以正常使用plugins&#xff01;&#xff01;&#xff01;

断电启动+智能插座 七彩虹B460主板实现电脑远程开机

BIOS设置操作步骤&#xff1a; 1&#xff0c;开机按F2进入BIOS系统&#xff08;小提示&#xff1a;不同的主板按键不一样&#xff0c;开机应该有提示&#xff09; 2&#xff0c;高级模式 > 高级 > 电源管理设置 > 交流电源恢复后处理 > 选择“开机” 3&#xff0c…

myabtis 数字+逗号 传参问题 $和#

大家好&#xff0c;我是烤鸭&#xff1a; 遇到一个maybatis传参的问题。 如果传参是数字逗号的形式&#xff0c;比如1,2,3,4,5。 问题复现&#xff1a; 项目中查询sql和navicat查询sql结果不一致。 1 项目中&#xff1a; 如图所示&#xff0c;查到一条数据。 可以看到…

SpringBoot上传文件到本服务器 目录与jar包同级

前言 看标题好像很简单的样子&#xff0c;但是针对使用jar包发布SpringBoot项目就不一样了。 当你使用tomcat发布项目的时候&#xff0c;上传文件存放会变得非常简单&#xff0c;因为你可以随意操作项目路径下的资源。但是当你使用SpringBoot的jar包发布项目的时候&#xff0c;…

org.apache.catalina.connector.ClientAbortException: java.io.IOException: Broken pipe

大家好&#xff0c;我是烤鸭&#xff1a; 又是采坑实录。 异常如下&#xff1a; org.apache.catalina.connector.ClientAbortException: java.io.IOException: Broken pipeat org.apache.catalina.connector.OutputBuffer.realWriteBytes(OutputBuffer.java:356)at org.ap…

低版本webview无法请求jquery ajax

大家好&#xff0c;我是烤鸭&#xff1a; 又来踩坑了。 1. 场景复现 有反馈我们的H5页面&#xff0c;无法正确显示页面。就类似下图这样&#xff0c;ajax没法请求到数据。 之前测试的时候是在web端做的测试&#xff0c;用安卓7.0和8.0的手机都试了一下&#xff0c;是没…

由excel导出引起的cpu 100% 和gc 的问题

大家好&#xff0c;我是烤鸭&#xff1a; 记一次 由excel导出 导致的cpu飙升200%&#xff0c;jvm 内存不足。 1. 场景复现 前端页面导出Excel&#xff0c;之前导出4,5W条数据都没什么问题的。 今天业务突然反馈说导出不了了&#xff0c;我试着导出了2w数据&#xff0…