Spring JPA使用findAll方法查出的数据跟数据库里存储的不一样

2024-04-04 00:38

本文主要是介绍Spring JPA使用findAll方法查出的数据跟数据库里存储的不一样,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

今天遇到个有意思的问题:findAll查出的数据竟然很数据库里存储的数据不一样

本来数据库里有全国所有省份的数据但是查出来只有河南和浙江的数据条数一样,数据大量重复

经过分析是Entity的ID字段在数据库中并不是唯一的,而且重复的很多,后来改成联合主键就正常了。

选ID的时候一定要确认是否是唯一的,因为JPA底层会根据这个ID判断俩个Entity是不是一样的。

以下是配置联合主键的代码:

/*** @Description:* @Author: tianlang* @Email: tianlangstudio@aliyun.com* @Date: 20-5-6 下午6:19*/
package email.tianlangstudio.aliyun.com.datav.model;import javax.persistence.*;
import java.math.BigDecimal;/*** 员工地域信息表* 包含省、市、员工个数信息*SELECT gsdm as 单位,nd as 年份,province as 省,city as 市,SUM(rgcb) AS 金额,SUM(sl) AS 数量  FROM map   GROUP BY gsdm,nd,province,city* ***/
@Entity
@Table(name = "map")
@IdClass(EmployeeRegionInfoKey.class)
public class EmployeeRegionInfo {/** 公司代码* **/@Id@Column(name = "gsdm")private String companyCode;/*** 年份* **/@Id@Column(name = "nd")private Integer year;/** 省名称* **/@Id@Column(name = "province")private String province;/*** 市名称* **/@Id@Column(name = "city")private String city;/*** 金额* **/@Column(name = "rgcb")private BigDecimal moneyAmount;/*** 数量* **/@Column(name = "sl")private Integer employeeAmount;public String getCity() {return city;}public void setCity(String city) {this.city = city;}public String getCompanyCode() {return companyCode;}public void setCompanyCode(String companyCode) {this.companyCode = companyCode;}public Integer getYear() {return year;}public void setYear(Integer year) {this.year = year;}public String getProvince() {return province;}public void setProvince(String province) {this.province = province;}public BigDecimal getMoneyAmount() {return moneyAmount;}public void setMoneyAmount(BigDecimal moneyAmount) {this.moneyAmount = moneyAmount;}public Integer getEmployeeAmount() {return employeeAmount;}public void setEmployeeAmount(Integer employeeAmount) {this.employeeAmount = employeeAmount;}
}
/*** @Description:* @Author: tianlang* @Email: tianlangstudio@aliyun.com* @Date: 20-5-7 下午1:47*/
package email.tianlangstudio.aliyun.com.datav.model;import org.springframework.context.annotation.Primary;import javax.persistence.Column;
import javax.persistence.Embeddable;
import java.io.Serializable;
import java.math.BigDecimal;//@Embeddable
//@Primary
public class EmployeeRegionInfoKey implements Serializable {/** 公司代码* **///@Column(name = "gsdm")private String companyCode;/*** 年份* **///@Column(name = "nd")private Integer year;/** 省名称* **///@Column(name = "province")private String province;/*** 市名称* **///@Column(name = "city")private String city;public String getCompanyCode() {if(companyCode == null) {companyCode = "";}return companyCode;}public void setCompanyCode(String companyCode) {this.companyCode = companyCode;}public Integer getYear() {return year;}public void setYear(Integer year) {this.year = year;}public String getProvince() {if(province == null) {province = "";}return province;}public void setProvince(String province) {this.province = province;}public String getCity() {if(city == null) {city = "";}return city;}public void setCity(String city) {this.city = city;}@Overridepublic boolean equals(Object obj) {EmployeeRegionInfoKey other = (EmployeeRegionInfoKey)obj;return other.getYear() == this.getYear() &&other.getCompanyCode().equals(this.getCompanyCode()) &&other.getProvince().equals(this.getProvince()) &&other.getCity().equals(this.getCity());}@Overridepublic int hashCode() {return (this.getCity() + this.getProvince() + this.getYear() + this.getCompanyCode()).hashCode();}
}

 

这篇关于Spring JPA使用findAll方法查出的数据跟数据库里存储的不一样的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直