gpt4 book ai didi

java - MongoRepository findByCreatedAtBetween 没有返回准确的结果

转载 作者:IT老高 更新时间:2023-10-28 13:25:46 26 4
gpt4 key购买 nike

我在 Mongo 中的文档结构是这样的:

db.user.find()

{
"_id" : ObjectId("560fa46930a8e74be720009a"),
"createdAt" : ISODate("2015-10-03T09:47:56.333Z"),
"message" : "welcome",
}
{
"_id" : ObjectId("560fa46930a8e723e720009a"),
"createdAt" : ISODate("2015-10-03T09:48:25.048Z"),
"message" : "thank you"
}

当我在 Mongo Shell 中使用以下查询来查找两个给定时间戳之间的文档时,我得到了正确的结果:

db.user.find({createdAt:{$gte:ISODate("2015-10-03T09:40:25.048Z"),$lte:ISODate("2015-10-03T09:50:56.333Z")}})

我在我的 REST 服务中使用带有 Spring 的 MongoRepository 来处理 Java 驱动程序。以下是用户存储库:

public interface UserRepository extends MongoRepository<User, String> 
{
ArrayList<User> findbyCreatedAtBetween(Date d1, Date d2);

}

当我在我的服务中进行以下调用时,它不会返回任何结果userRepository.findbyCreatedAtBetween(2015-10-03T09:40:25.048Z, 2015-10-03T09:50:29.006Z)

但是,当我将 d1 作为前一天给出时,它会返回结果: userRepository.findbyCreatedAtBetween(2015-10-02T09:40:25.048Z, 2015-10-03T09:50:29.006Z)

关于如何解决此问题的任何想法?请帮忙!

最佳答案

分解一下,使用关键字 Between 的查询正在对 MongoDB 数据库执行逻辑结果 {"createdAt" : {"$gt" : d1, "$lt" : d2}}所以有可能您没有得到具有 createdAt 的文档给定日期范围内的包含日期,即 d1 < createdAt < d2因为给定的日期范围不满足条件。作为引用,这些是对 query methods 的一些解释。 :

查询方法支持的关键字

Keyword     Sample                              Logical result
After findByBirthdateAfter(Date date) {"birthdate" : {"$gt" : date}}
Before findByBirthdateBefore(Date date) {"birthdate" : {"$lt" : date}}
Between findByAgeBetween(int from, int to) {"age" : {"$gt" : from, "$lt" : to}}

作为一种解决方法,您可能需要使用 @Query 注释。我尚未对此进行测试,但您可能想尝试以下自定义查询实现示例:

public interface UserRepository extends MongoRepository<User, String>  {
@Query(value = "{ 'createdAt' : {$gte : ?0, $lte: ?1 }}")
public ArrayList<User> findbyCreatedAtBetween(Date from, Date to);
}

如果上述方法对您不起作用,请创建一个自定义接口(interface)和您的实现类来执行自定义查询。例如,创建一个名称附加 Custom 的接口(interface)。 :

public interface UserRepositoryCustom {
public List<User> findbyCreatedAtBetween(Date from, Date to);
}

修改UserRepository并添加 UserRepositoryCustom待扩展接口(interface):

@Repository
public interface UserRepository extends UserRepositoryCustom, MongoRepository {

}

创建您的实现类来实现UserRepositoryCustom 中定义的方法界面。

public class UserRepositoryImpl implements UserRepositoryCustom {

@Autowired
MongoTemplate mongoTemplate;

@Override
public ArrayList<User> findbyCreatedAtBetween(Date from, Date to) {
return mongoTemplate.find(
Query.addCriteria(Criteria.where("createdAt").gte(from).lte(to));
}
}

关于java - MongoRepository findByCreatedAtBetween 没有返回准确的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33494444/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com