查询多对多关系的数据时避免出现重复

2023-11-23 09:10

本文主要是介绍查询多对多关系的数据时避免出现重复,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

数据的关系有三种,一对一、一对多以及多对多。处理难度上多对多的关系的数据是最难处理的,多对多的关系一般用在一些类型上,例如一个客户对应多个客户类型,一个类型又可以对应多个客户,这样就形成了多对多关系了。多对多关系在查询数据时一般回查出多条数据,就例如上面的客户以及客户类型,一般显示到页面时每个客户只需要出现一次就行,但是又要显示出所有的客户类型。但是如何按一般的联表查询得到的结果就是该客户有多少个客户类型就会显示有多少条该客户的信息。就如下图所示,中谷新良这个客户有三个客户类型,而这个公司就出现了三遍。

       因为不需要客户出现多次,所有接着需要做的就是把重复的客户去除掉,把客户类型拼接起来集中显示到一条该客户的信息上。

    首先,要连表查询出每个客户的客户类型,也就是说每条数据都必须要有客户ID和客户类型两个字段。

       然后需要声明三个变量,一个是存放客户类型的,就是把每个客户的客户类型处理好了之后临时存放到这个变量里面;第二个是存放客户ID的,这个变量主要是用来筛选客户的,这是去重复了的核心代码;第三个变量是一个列表,把最终处理好的客户以及客户类型放到里面,供后续操作继续使用,是连接的桥梁。

    CustomerVo是实体类,自己创建的,内容根据实际添加。

    接着就可以对上面查询出来的数据进行处理了,处理时需要用到两个foreach循环,而且属于嵌套关系,循环的内容都是上面查询出来的每个客户的客户类型。第一个foreach循环是为了筛选客户的,第二个foreach循环是为了筛选客户类型的。先看看第二个foreach循环,一进去到第二个foreach循环就立马要进行判断,如果第一个循环的客户ID等于第二个循环的客户ID就可以进行客户类型的拼接,因为既然客户ID相等了那这个客户类型肯定就是该个客户的了。

    拼接完成后,就要对上面声明的几个变量进行处理,处理这几个变量的地方一定是要在第二个循环的外面,因为客户类型是要显示到页面上的,为了美观一般都会去掉最后一拼接的符号。

然后就要为列表添加数据了,客户类型添加的是第一个循环的客户ID,类型是拼接好的客户类型。添加完成后就要吧客户类型这个变量清空,避免影响下一次的操作。最后把客户ID拼接上,这时为了在第一个循环里进行判断是否已经处理过该客户。

    图中红色圈内的是筛选客户的操作,也就是去重复,首先要把拼接好的客户ID分割成数组形式,再利用Contains这个属性去判断该次的客户是否在该数组中,存在返回true,不存在返回false,如果存在就不进行任何操作,不存在就继续进行第二个循环。使用Contains一定要注意,该数组一定是一个字符串数组,而且前面要要IList这个属性,否则是使用不了的。

    然后就可以接着在下面正常的连表操作了,但是需要查询客户类型是就需要连处理好的那张表,就是listCustomerType这张。

 

    处理好之后就是这样子的

 

这篇关于查询多对多关系的数据时避免出现重复的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/416863

相关文章

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

MyBatis-plus处理存储json数据过程

《MyBatis-plus处理存储json数据过程》文章介绍MyBatis-Plus3.4.21处理对象与集合的差异:对象可用内置Handler配合autoResultMap,集合需自定义处理器继承F... 目录1、如果是对象2、如果需要转换的是List集合总结对象和集合分两种情况处理,目前我用的MP的版本

如何通过try-catch判断数据库唯一键字段是否重复

《如何通过try-catch判断数据库唯一键字段是否重复》在MyBatis+MySQL中,通过try-catch捕获唯一约束异常可避免重复数据查询,优点是减少数据库交互、提升并发安全,缺点是异常处理开... 目录1、原理2、怎么理解“异常走的是数据库错误路径,开销比普通逻辑分支稍高”?1. 普通逻辑分支 v

GSON框架下将百度天气JSON数据转JavaBean

《GSON框架下将百度天气JSON数据转JavaBean》这篇文章主要为大家详细介绍了如何在GSON框架下实现将百度天气JSON数据转JavaBean,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录前言一、百度天气jsON1、请求参数2、返回参数3、属性映射二、GSON属性映射实战1、类对象映

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.