用springboot整合mongodb,使用其中的带条件(example)查询,查询不出数据

遇到的问题:
用springboot整合mongodb,使用其中的带条件(example)查询,查询不出数据
但是使用其他的方法查询都可以查询出来数据

代码:

   Actor actor = new Actor();
        actor.setGender(true);
        Example example=Example.of(actor);
        List all = actorRepository.findAll(example);
        for (Actor actor1 : all) {
            System.out.println(actor1);
        }

数据库信息:

img


pojo类信息:

img

该回答引用自ChatGPT

如果字段名正确,数据也有,那么可能是查询条件设置有误或者查询条件中的数据类型不匹配导致查询不出数据。
可以尝试以下方法来排查问题:

  1. 确认查询条件是否正确设置,并且与数据库中的数据类型匹配。例如,如果查询条件是一个字符串类型的字段,但是数据库中存储的是数字类型的数据,那么查询是不会返回任何结果的。

  2. 尝试使用其他类型的查询条件,例如使用Query和Criteria等方式来查询数据,看是否能够查询到数据。如果其他类型的查询条件可以查询到数据,那么可能是Example查询条件设置有误。

    Query query = new Query(Criteria.where("gender").is(true));
    List<Actor> actors = mongoTemplate.find(query, Actor.class);
    for (Actor actor : actors) {
     System.out.println(actor);
    }
    

实体类加个@Document("actor")

上面的pojo类没有截完整

img

可以尝试使用MongoDB的原生查询语句来查询数据,例如使用find()方法。也可以检查条件是否正确,或者是数据是否存在。另外,也可以尝试使用其他的查询方法,例如使用MongoTemplate或者是MongoRepository提供的其他查询方法。如果仍然无法查询到数据,可以检查数据库连接是否正常,或者是数据是否正确插入到数据库中。