如何检查类实例的存在

问题描述 投票:0回答:1

我想检查一下我女人班中是否存在某个字段。该字段是其自己的(丈夫)类,而女性和丈夫都是存储在数据库中的实体。 Husband类未在Woman类的构造函数中初始化。在程序的稍后阶段,在我操作Woman类的一些实例之后,我想检查Woman类的哪些条目仍然没有Husband类实例(并且在初始化它们的情况下)。我需要使用JpaQueries API执行此操作。基本上我想编写规范“WithNoHusband”来查看我的数据库。

到目前为止,我尝试过类似的东西

(root,query,cb) -> { 
    Join<Woman, Husband> husbandJoin = root.join(husband); 
    return cb.equal(husbandJoin.isNull(), true); 
};

在我的JpaWomanSpecificationAdapter类和

@Value
class WithNoHusband implements WomanSpecification {

@Override
public boolean isSatisfiedBy(Woman object) {
        return object.getHusband() == null;
}

}

在我的WomanSpecification课程中没有运气。

当我想检查女人是否有任何汽车时,我需要做的就是

private org.springframework.data.jpa.domain.Specification<Woman> toJpaSpecification(WithNoCar specification) {
    (root,query,cb) -> cb.isEmpty(root.get(car)); 
}

@Value
class WithNoCar implements WomanSpecification {

@Override
public boolean isSatisfiedBy(Woman object) {
        return object.getCar().isEmpty();
    }
}

在各自的班级。

这是三个班级的基本结构

 public class Woman{ 

    @Id
    Integer id;
    @Column
    String name;
    @OneToOne(mappedBy = "maintenanceImplementation", cascade = ALL, orphanRemoval = true)
    @Getter
    Husband husband;
    @oneToMany(mappedBy = "maintenanceImplementation", cascade = ALL, orphanRemoval = true)
    @Getter
    List<Car> car;
    @Column
    @Enumerated(STRING)
    @Getter
    Type typeOfWoman;

    public Woman(Integer id, String name){
        this.is=id;
        this.name=name;
        this.car = new ArrayList<>();
    }
}

public class Husband {

    @Id
    Integer Id;
    @OneToOne
    @JoinColumn(name = "WomanId", nullable = false)
    @Getter
    @Setter(PACKAGE)
    private Woman Woman;
    @Column
    String name;
}

public class Car {
    @Id
    Integer Id;
    @ManyToOne
    @JoinColumn(name = "WomanId", nullable = false)
    @Getter
    @Setter(PACKAGE)
    private Woman Woman;
    @Column
    String brand;
}

我期待的是,对于丈夫来说,使用NoHusband的规范将返回true为isNull条件。

当然,Car已被初始化为女性的构造函数中的空列表,因此可以简单地查询该列表是否为空(没有拼写出连接子句)但是在为丈夫提供了join子句之后,为什么查询的结果选择所有没有汽车和没有丈夫的女性仍然是这样的

unexpected AST node: is near line 1, column 485 [select generatedAlias0 
from Woman as generatedAlias0, Woman as generatedAlias1 inner join
generatedAlias1.husband as generatedAlias2 where ( ( 
generatedAlias0.status=:param0 ) and ( generatedAlias0.cars is empty ) ) and 
( generatedAlias2 is null=:param1 )]

?

PS:我需要丈夫不要在WOMAN的构造函数中初始化,因为(到目前为止)丈夫的存在是基于typeOfWoman,所以如果typeOfWoman是“寡妇”,丈夫不需要初始化。

jpa criteria-api
1个回答
0
投票

FEI,我犯的错误是创建一个INNER JOIN子句(默认情况下在Criteria API中)(root,query,cb) - > {Join husbandJoin = root.join(丈夫,左); return cb.equal(husbandJoin.isNull(),true); };做了诀窍......

© www.soinside.com 2019 - 2024. All rights reserved.