7

Mongo での私のドキュメント構造は次のようになります。

デシベル.ユーザー.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 で以下のクエリを使用して、指定された 2 つのタイムスタンプの間のドキュメントを検索すると、正しい結果が得られます。

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

Java ドライバーを操作するために、REST サービスで Spring と共に MongoRepository を使用しています。以下はユーザーリポジトリです。

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)

これを解決する方法についてのアイデアはありますか? 助けてください!

4

1 に答える 1

13

分解すると、キーワードBetweenを含むクエリが MongoDB データベースに対して実行され、論理的な結果が得られるため、指定された日付範囲内の日付を含む{"createdAt" : {"$gt" : d1, "$lt" : d2}}ドキュメントを取得できない可能性があります。つまり、指定された日付範囲が含まれていないためです。基準を満たします。参考までに、これらはクエリ メソッドの解釈の一部です。createdAtd1 < createdAt < d2

クエリ メソッドでサポートされているキーワード

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);
}

上記がうまくいかない場合は、カスタム インターフェイスと実装クラスを作成して、カスタム クエリを実行します。たとえば、名前に を追加したインターフェイスを作成しますCustom

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

を変更し、拡張UserRepositoryするインターフェイスを追加しUserRepositoryCustomます。

@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));
    }
}
于 2015-11-03T09:16:06.207 に答える