【问题标题】:How to filter by child object property with QuerydslPredicate?如何使用 QuerydslPredicate 按子对象属性进行过滤?
【发布时间】:2019-08-31 03:47:00
【问题描述】:

我有一个“Pet”域和一个“Person”域,一个人可能有一只宠物。在我的 RestController 上使用 QuerydslPredicate,我想只返回拥有“DOG”类型宠物的人。

宠物.java

@Entity
public class Pet {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column(nullable = false)
    private String name;

    @Enumerated(EnumType.STRING)
    @Column(nullable = false, name = "animal_type")
    private AnimalType type;

    // constructors & getters/setters
}


enum AnimalType {
    DOG, CAT
}

Person.java

@Entity
public class Person {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column(nullable = false)
    private String name;

    @Column(nullable = false)
    private String surname;


    @OneToOne(fetch = FetchType.EAGER, cascade = CascadeType.PERSIST)
    @JoinColumn(name = "pet_id")
    private Pet pet;

    // constructors & getters/setters
}

PersonController.java

@RestController
@RequestMapping("persons")
public class PersonController {

    @Autowired
    private PersonRepository personRepository;

    @GetMapping
    public List<Person> getAll(@QuerydslPredicate(root = Person.class) Predicate predicate)
    {
        return (List<Person>) personRepository.findAll(predicate);
    }
}

PersonRepository.java

public interface PersonRepository extends JpaRepository<Person, Long>, QuerydslPredicateExecutor<Person> {
}

我只想通过这样的 GET 请求查询养狗的人:

localhost:8080/persons?pet.type=DOG

但这会导致以下错误:

{
    "timestamp": "2019-04-09T18:11:23.430+0000",
    "status": 500,
    "error": "Internal Server Error",
    "message": "Could not access method: Class org.springframework.util.ReflectionUtils can not access a member of class com.example.demo.domain.QPerson with modifiers \"protected\"",
    "path": "/persons"
}

使用localhost:8080/persons?name=Tom 查询名为“Tom”的人可以正常工作。

我有这个 repo 可用here

我已经尝试过来自thisthisthisthis stackoverflow 问题的解决方案,但还不能解决。

【问题讨论】:

    标签: java h2 querydsl


    【解决方案1】:

    只需将pom.xml 中的querydsl.entityAccessors 属性更改为false(或删除它,默认值为false)。

    为什么会这样?

    在您的pom.xml 中,您有以下配置:

    <querydsl.entityAccessors>true</querydsl.entityAccessors>
    

    此选项使您的关系在您的类中创建为protected 方法,因此您的错误 (https://github.com/querydsl/querydsl/blob/master/querydsl-codegen/src/main/java/com/querydsl/codegen/EntitySerializer.java#L211)。

    if (config.useEntityAccessors()) {
        writer.protectedField(queryType, field.getEscapedName());
    } else {
        writer.publicFinal(queryType, field.getEscapedName());
    }
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2016-08-28
      • 1970-01-01
      • 1970-01-01
      • 2016-02-08
      • 1970-01-01
      • 2017-09-22
      • 2017-05-25
      相关资源
      最近更新 更多