Опитах този вид съставен индекс в моето приложение, който също използва пролетни данни и работи правилно. Трябва само да коригирате дефиницията на индекса в @CompoundIndex
анотация:
@CompoundIndex(name = "aid_bid_idx", def = "{'id' : 1, 'b.id' : 1}")
@Document(collection = "doc_a")
public class A {
@Field("id")
private Integer id;
@Field("b")
private Collection<B> b;
...
}
public class B {
@Field("id")
private Integer id;
...
}
Ако изпълните заявка с обяснение (като по-долу) в mongo shell, ще видите, че ще се използва индексът *aid_bid_idx*.
db.doc_a.find({ "id" : 1, "b.id" : 1}).explain()
Резултатът ще бъде нещо подобно:
{
"cursor" : "BtreeCursor aid_bid_idx",
...
}