【问题标题】:MongoDB and Spring MVC: PATCH operation?MongoDB 和 Spring MVC:PATCH 操作?
【发布时间】:2020-02-04 23:51:18
【问题描述】:

我有以下简单的Java 控制器和Spring Web 框架:

@RestController
@RequestMapping("/rounds")
@Slf4j
public class RoundController {

    private RoundService roundService;

    @Autowired
    public RoundController(RoundService roundService) {
        this.roundService = roundService;
    }

    @GetMapping(
        produces = MediaType.APPLICATION_JSON_VALUE)
    @ResponseStatus(HttpStatus.OK)
    public List<Round> find() {

        return roundService.find();
    }

    @GetMapping(
        path = "/{userId}",
        produces = MediaType.APPLICATION_JSON_VALUE)
    @ResponseStatus(HttpStatus.OK)
    public List<Round> get(@PathVariable String userId) {

        return roundService.getRoundsByUserId(userId);
    }

    @PostMapping(
        produces = MediaType.APPLICATION_JSON_VALUE
    )
    @ResponseStatus(HttpStatus.CREATED)
    public Round create(@Valid @NotNull @RequestBody Round round) {

        roundService.create(round);

        return round;
    }

    @DeleteMapping(
        path = "/{id}",
        produces = MediaType.APPLICATION_JSON_VALUE
    )
    @ResponseStatus(HttpStatus.OK)
    public void delete(@PathVariable String id) {

        ObjectId objectId = new ObjectId(id);

        roundService.delete(objectId);
    }
}

在使用Mongo 时,是否有对对象进行更新/修补的最佳做法?

最好只使用POST 方法,并使用用户所做的更改将Round 对象重新保存在数据库中吗?

【问题讨论】:

    标签: java spring mongodb rest patch


    【解决方案1】:

    在我看来,最佳实践不应该是使用 POST 进行更新/修补。

    让你只做回合创建。

    如果您使用 spring data mongodb,只需使用您的实体调用存储库的 save 方法 见https://docs.spring.io/spring-data/mongodb/docs/current/api/org/springframework/data/mongodb/repository/MongoRepository.html

    对于更新,最好在控制器中添加 PUT /{roundId} 或者:

    • 如果您拥有所有 Round 数据,请调用您的保存方法
    • 调用 findById 获取完整数据并设置要更改的数据,然后保存(但这更像是 PATCH)

    或者您也可以添加 PATCH /{roundId} 并仅更新文档中所需的字段 见https://docs.spring.io/spring-data/mongodb/docs/current/api/org/springframework/data/mongodb/core/MongoTemplate.html

    【讨论】: