2016-08-30 9 views
0
@Document(collection="users") 
public class User{ 
    @Id 
    private int id; 

    private String name; 
    ... 
    //getters-setters 
} 

@Document(collection="models") 
public class Model{ 
    @Id 
    private int id; 
    private String name; 
    @DBRef 
    private List<User> users; 
    ... 
    //getters-setters 
} 

Я попытался это решение, но оно не вернуть ничего:Spring MongoDB + QueryDSL запрос по @DBRef связанных список

QModel модель = новый QModel(); Pageableableable = new PageRequest (0, 100);

return modelsRepository.findAll (model.users.any(). Id.eq (anUserId), доступен для просмотра);

+0

Просто интересно, полезен ли ответ? – notionquest

ответ

0

Я думаю, все зависит от данных JSON в коллекции MongoDB.

В вашем случае коллекция моделей должна иметь атрибут «users» Array. Пока имя ключа совпадает (например, «пользователи»), оно должно работать.

Подробный пример: -

Следующий пример работает нормально.

Люди Коллекция: -

{ 
    "_id" : ObjectId("57c8269b3ee7df409d4d2b64"), 
    "name" : "Erin", 
    "places" : [ 
     { 
      "$ref" : "places", 
      "$id" : ObjectId("57c813b33ee7df409d4d2b58")     
     } 
    ], 
    "url" : "bc.example.net/Erin" 
} 

мест Коллекция: -

{ 
    "_id" : ObjectId("57c813b33ee7df409d4d2b58"), 
    "name" : "Broadway Center", 
    "url" : "bc.example.net" 
} 

Классы: -

мест Класс: -

@Document(collection = "places") 
public class Places implements Serializable { 

    private static final long serialVersionUID = -5500334641079164017L; 

    @Id 
    private String id; 

    private String name; 

    private String url; 

    ...get and setters 
} 

Люди класса: -

@Document(collection = "people") 
public class People implements Serializable { 

    private static final long serialVersionUID = 6308725499894643034L; 

    @Id 
    private String id; 

    private String name; 

    @DBRef 
    private List<Places> places; 

    private String url; 

    ...get and setters 
} 

Repository класс: -

@Repository 
public interface PeopleRepository extends PagingAndSortingRepository<People, String> { 

    public People findById(String id); 

    @Query(value = "{ 'status' : ?0 }") 
    public Page<People> findByStatus(String status, Pageable pageable); 

} 

FindAll: -

public Boolean findAllPeople() { 

     Page<People> peoplePage = peopleRepository.findAll(new PageRequest(0, 20)); 

     System.out.println("Total elements :" + peoplePage.getTotalElements()); 

     for (People people : peoplePage) { 
      System.out.println("People id :" + people.getId()); 
      System.out.println("Place size :" + people.getPlaces().size()); 
      people.getPlaces().forEach(p -> System.out.println(p.getName())); 
     } 

     return true; 

    }