jpa 去重_spring boot jpa 表关联查询分组 group by 去重

使用jpa操作多张表进行关联查询时,有重复数据需要分组去重

1)确定主表:将有重复数据的表格作为主表,表明关系

public class AttendanceRuleTypeItem implements Serializable {

@Id

@GeneratedValue(strategy = GenerationType.IDENTITY)

private Long itemId;

private String name;

private Integer code;

private String dictionaryCode;

@OneToMany

@JoinColumn(name = "typesCode",referencedColumnName = "code")

private List attendanceRules;

}

2.副表两张

public class AttendanceRuleModel {

@Id

@GenericGenerator(name = "guid", strategy = "guid")

@GeneratedValue(generator = "guid")

private String id;

//规则类型code

private Integer ruleCode;

//请假类型code

private Integer typesCode;

//扣罚天数code

private Integer resultNumberCode;

private String rankName;

@OneToOne

@JoinColumn(name = "resultNumberCode", referencedColumnName = "code", insertable = false, updatable = false,

foreignKey = @ForeignKey(value =ConstraintMode.NO_CONSTRAINT ))

private AttendanceRuleTypeItem resultNumber;

@OneToMany(cascade = {CascadeType.PERSIST,CascadeType.REFRESH,CascadeType.MERGE})

@JoinColumn(name = "rule_id",referencedColumnName = "id",foreignKey = @ForeignKey(value =ConstraintMode.NO_CONSTRAINT ))

private List departmentRelation;

@OneToMany(cascade = {CascadeType.PERSIST,/*CascadeType.REMOVE,*/CascadeType.REFRESH})

@JoinColumn(name = "attendance_rule_id",referencedColumnName = "id",foreignKey = @ForeignKey(value =ConstraintMode.NO_CONSTRAINT ))

private List relationAttendanceRanks;

}

public class RelationAttendanceDepartment extends BaseEntity {

@Id

@GeneratedValue(generator = "guid")

@GenericGenerator(strategy = "guid",name = "guid")

private String ruleDeptId;

@Column(name = "rule_id")

private String ruleId;

private Integer departmentId;

public RelationAttendanceDepartment(Integer departmentId) {

this.departmentId = departmentId;

}

public RelationAttendanceDepartment(String ruleId, Integer departmentId) {

this.ruleId = ruleId;

this.departmentId = departmentId;

}

}

3)。确定每张表的关系之后  表连接查询

public PageResultVO> ruleList(QueryPageVO attendance) {

Specification reSpec = (Specification) (root, cq, cb) -> {

Join ruleJoin = root.join("attendanceRules", JoinType.LEFT); //表关联查询 AttendanceRuleTypeItem 为主表

Join deptJoin = ruleJoin.join("departmentRelation", JoinType.LEFT); //两张副表之间的关联关系

Predicate predicate = cb.conjunction();

predicate = cb.and(predicate, cb.equal(deptJoin.get("departmentId"), attendance.getQuery().getId())); //拼接副表中的查询条件

predicate = cb.and(predicate, cb.equal(root.get("dictionaryCode"), "1002")); //拼接朱表中的查询条件

predicate = cb.and(predicate, cb.equal(ruleJoin.get("ruleCode"), 2001)); //拼接副表中的查询条件

cq.where(predicate);

return cq.getRestriction();

};

Page ruleTypeItemPage = ruleTypeItemRepository.findAll(Specification

.where(reSpec)

.and(distinct()), PageRequest.of(attendance.getPages().getPage(), attendance.getPages().getSize()));

List attendanceRuleResultVOS = ruleTypeItemPage.stream().map(r->{

AttendanceRuleResultVO ruleResultVO =new AttendanceRuleResultVO();

ruleResultVO.setTypesName(r.getName());

List ruleVOS = r.getAttendanceRules().stream().map(a-> new RuleVO(a.getId(),getRankName(a),

a.getResultNumber().getName())).collect(Collectors.toList());

ruleResultVO.setRule(ruleVOS);

return ruleResultVO;

}).collect(Collectors.toList());

return new PageResultVO(ruleTypeItemPage.getTotalPages(),(int)ruleTypeItemPage.getTotalElements(),null, attendanceRuleResultVOS);

}

//去重

public Specification distinct() {

return (Root root, CriteriaQuery> criteriaQuery, CriteriaBuilder criteriaBuilder) -> {

criteriaQuery.distinct(true);

return criteriaQuery.getRestriction();

};

}

来源:https://www.cnblogs.com/xiaoxiaoliu/p/10190065.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring Boot中,可以使用Spring Data JPA和JPQL(Java Persistence Query Language)来实现count group by操作。 首先,需要定义一个Entity类,包含要分组和计数的属性。假设我们有一个实体类叫做Order,包含属性id、customerId和price: ```java @Entity @Table(name = "orders") public class Order { @Id @GeneratedValue(strategy = GenerationType.IDENTITY) private Long id; @Column(name = "customer_id") private Long customerId; private Double price; // getters and setters } ``` 然后,使用Spring Data JPA定义一个Repository接口,继承JpaRepository,并声明一个查询方法,使用JPQL实现count group by操作: ```java @Repository public interface OrderRepository extends JpaRepository<Order, Long> { @Query("SELECT o.customerId, COUNT(o.id) FROM Order o GROUP BY o.customerId") List<Object[]> countGroupByCustomerId(); } ``` 在这个方法中,我们使用JPQL查询语句"SELECT o.customerId, COUNT(o.id) FROM Order o GROUP BY o.customerId"来实现count group by操作。这个查询语句会返回一个Object数组的列,每个数组包含两个元素,第一个元素是customerId,第二个元素是该customerId下的订单数量。 最后,可以在Service层调用这个方法并处理返回的结果: ```java @Service public class OrderService { @Autowired private OrderRepository orderRepository; public Map<Long, Long> countGroupByCustomerId() { List<Object[]> list = orderRepository.countGroupByCustomerId(); Map<Long, Long> map = new HashMap<>(); for (Object[] obj : list) { Long customerId = (Long) obj[0]; Long count = (Long) obj[1]; map.put(customerId, count); } return map; } } ``` 在Service层中,我们调用OrderRepository的countGroupByCustomerId方法获取结果列,然后将结果转换为一个Map<Long, Long>,其中key是customerId,value是该customerId下的订单数量。 这样,就实现了在Spring Boot中使用Spring Data JPA和JPQL实现count group by操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值