首页 > 解决方案 > 使用 spring webflux-reactor 进行嵌套数据访问调用

问题描述

我正在尝试使用 spring webflux/reactor 对数据库进行嵌套调用,以返回嵌套对象的 Mono(具有他的角色的用户)。

场景如下:

上面的场景必须在没有阻塞的情况下完成(我知道映射是一个很小的阻塞:))。

public Mono<User> retrieveByUsername(String username)  {
    return databaseClient.execute(usersQueries.getProperty("users.select.by.username"))
            .bind("username", username.toLowerCase())
            .map((row, meta) -> UserRowMapper.mapRow(row, meta))
            // here goes nested database query to retrieve roles and set them to retrieved user 
            // and return Mono<User>
            .one();
}

预先感谢您的帮助。

标签: spring-dataspring-webfluxproject-reactorreactor-netty

解决方案


以下是我如何看待您的问题的解决方案:

public Mono<User> retrieveByUsername(String username) {
    Mono<User> userMono = databaseClient
            .execute(usersQueries.getProperty("users.select.by.username"))
            .<User>map((row, meta) -> UserRowMapper.mapRow(row, meta))
            .one()
            .cache();

    Flux<Role> roles = Mono
            .from(userMono)
            .flatMapMany(user -> databaseClient
                    .execute(usersQueries.getProperty("roles.select.by.user.id"))
                    .bind("userId", user.getId())
                    .<Role>map((row, meta) -> RoleRowMapper.mapRow(row, meta))
                    .all()
            );

    return Mono
            .from(userMono)
            .flatMap(user -> roles
                    .collectList()
                    .map(r -> {
                        user.setRoles(r);
                        return user;
                    })
            );
}

推荐阅读