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 语句。类似下图
mybatis 一对一 一对多 级联查询相关推荐
- mybatis mapper 一对多分页查询
1. 使用级联查询解决一对多分页问题 下面的 mapper 语句为第一个版本,其中还存在一个bug,级联查询没有办法解决带条件的查询问题. <resultMap id="Product ...
- 高性能架构学习路线图-分布式架构演进,mybatis一对一一对多面试题
架构演进一: 早期雏形 架构演进二: 数据库开发(LAMP特长) 架构演进三: javaweb的雏形 架构演进四: javaweb的集群发展 架构演进五: javaweb的分布式发展 架构演进 ...
- MyBatis级联查询
文章目录 MyBatis级联查询 简介 一对一 创建数据库初始数据 创建实体类 创建Mapper类及XML 提供两次方式xml进行查询,代码均在StudentMapper .xml 分步查询 单步查询 ...
- MyBatis框架学习 DAY_03:如何解决无法封装问题 / 一对一关联查询 / 一对多关联查询
1. 通过查询时自定义别名的方式解决名称不一致而导致的无法封装数据的问题 假设,向用户组数据表(t_group)表中插入一些测试数据: INSERT INTO t_group (name) VALUE ...
- mybatis一对多关联 创建_MyBatis多对多关联查询(级联查询)
其实,MyBatis 没有实现多对多级联,这是因为多对多级联可以通过两个一对多级联进行替换. 例如,一个订单可以有多种商品,一种商品可以对应多个订单,订单与商品就是多对多的级联关系,使用一个中间表(订 ...
- 7. MyBatis多表查询 - 一对一 - 一对多 - 多对多
7. MyBatis多表查询 - 一对一 - 一对多 - 多对多 前言 在前面的篇章,我们已经熟悉了单表查询,下面我们来看看如何进行 多表查询. 数据准备 create database if not ...
- MyBatis如何实现多表查询(一对一、一对多)
Mybatis实现多表的查询分为以下两种: 方式一:sqlMapper配置文件 一对一:在resultMap标签中使用 association 标签 一对多:在resultMap 标签中使用colle ...
- mybatis一对多关联查询_Mybatis 一对一、一对多的关联查询 ?
<mapper namespace="com.lcb.mapping.userMapper"> <!--association 一对一关联查询 --> &l ...
- mybatis级联查询list_MyBatis手把手跟我做系列(四) ---级联查询与懒加载
涉及到数据库的级联查询,那肯定就要提到一对一,一对多,多对多这样的表关系,以及java程序与之对应的类和类之间的表现形式,我这里主要通过一对多的表关系给大家介绍以下MyBatis里面对于级联关系的处理 ...
最新文章
- Verilog初级教程(20)Verilog中的`ifdef 条件编译语句
- 第四节:python if语句用法
- mysql平台workb_MySQL分布式事务
- 【学习笔记】HTTPS概述
- 阿里将在雄安新区设3家子公司:涉AI、蚂蚁金服和菜鸟;北航设立全国首个人工智能专业,与百度合作办学...
- asp.net 连接字符串的多种写法
- mysql128位整数_mysql的数据类型
- linux中查找某一个字符串,linux下查找包含某个字符串的文件
- 微软Skype Translator将支持阿拉伯语即时语音翻译
- 教你玩转CSS 伪元素
- 如何优雅地使用 VSCode 来编辑 vue 文件?
- [转]访问 OData 服务 (WCF Data Services)
- 《企业IT架构转型之道》阿里巴巴中台战略思想和架构实战-书摘整理
- HTML之如何创建表格?
- 天然产物数据库综述:2020年从哪里找天然产物数据
- MsgBox函数用法小结
- 浅析物联网行业市场最新发展趋势
- 流媒体服务器主板型号怎么看,玩转NAS 篇五:双2.5G接口+J4125处理器,对于NAS意味着什么?威联通453Dmini对比453Bmini...
- Unity捕鱼达人5-----鱼群的生成
- 区块链实战(一)实现简单的区块与区块链交易