如何使用QuerydslPredicate按子对象属性过滤?

拉马里亚诺

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

宠物

@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
}

人.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"
}

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

在这里有这个仓库

我已经尝试过thisthisthis这个stackoverflow问题的解决方案,但是还不能使它工作。

Finx

只需将您的querydsl.entityAccessors属性更改pom.xml为即可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());
}

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章