3

我正在尝试在模型中使用列表,@DBRef但我无法让它工作。这是我的用户模型:

@Data
@Document
public class User {

    @Id
    @JsonSerialize(using = ToStringSerializer.class)
    private ObjectId id;

    @Indexed(unique = true)
    @NotBlank
    private String email;

    @NotBlank
    private String name;

    @NotBlank
    private String password;

    @DBRef
    private List<Server> servers;
}

服务器型号:

@Data
@Document
public class Server {

    @Id
    @JsonSerialize(using = ToStringSerializer.class)
    private ObjectId id;

    @NotBlank
    private String name;

    @NotBlank
    private String host;
}

结构很简单,每个用户可以有多个服务器。但是当我向用户添加服务器时,会创建服务器,但服务器数组包含一个null条目("servers" : [ null ])。所以服务器不会添加到用户。这就是我创建服务器并将其添加到用户的方式:

@PostMapping
public Mono create(@Valid @RequestBody Server server, Mono<Authentication> authentication) {
    return this.serverRepository.save(server).then(authentication.flatMap(value -> {
        User user = (User) value.getDetails();
        user.getServers().add(server);

        return userRepository.save(user);
    })).map(value -> server);
}

所以我只需创建并保存一个服务器,将服务器添加到用户,然后保存用户。但它不起作用。我一直有一个包含一个null条目的数组。

我看过这个页面:http ://www.baeldung.com/cascading-with-dbref-and-lifecycle-events-in-spring-data-mongodb 。但它是用于保存子文档,而不是用于链接它。它也适用于单个文档,而不适用于数组或列表。

为什么我的列表没有正确保存?

我所有的库都来自 spring boot 版本2.0.0.M6

更新从用户的服务器属性中 删除@DBRef时,服务器将被保存,但它们当然会在server集合和每个user.servers. 所以错误与引用有关。

4

3 回答 3

2

经过一番谷歌搜索后,我找到了答案......
https://jira.spring.io/browse/DATAMONGO-1583
https://jira.spring.io/browse/DATAMONGO-1584

反应式 mongo 不支持这一点。

于 2017-11-22T20:06:14.580 回答
0

实际上有一种方法可以在不使用阻塞驱动程序的情况下解决 DbRefs。是的 - 引用以阻塞方式解析,但不需要第二个连接。为了实现这一点,我们必须编写自己的 DbRefResolver:NbDbRefResolver.java。在提供的解析器中有一个标志:RESOLVE_DB_REFS_BY_ID_ONLY。如果打开,将不会从数据库中解析 DbRefs,而是将它们解析为仅具有 id 的假对象。稍后以非阻塞方式填充引用取决于实现。

如果标志 RESOLVE_DB_REFS_BY_ID_ONLY 设置为 false,它将使用非阻塞驱动程序急切地解析引用,但会阻塞执行,直到解析引用。以下是在应用程序中注册 DbRefResolver 的方法:DbConfig.kt

此处提供附加文件:https ://jira.spring.io/browse/DATAMONGO-1584

于 2018-03-30T06:44:20.813 回答
0

Me did it like that for roles :

  @Unwrapped(onEmpty = Unwrapped.OnEmpty.USE_NULL)
  private Collection<Role> roles;

you can check the doc (2021) here : https://spring.io/blog/2021/04/20/what-s-new-in-spring-data-2021-0

于 2021-09-04T14:07:14.270 回答