在很多平常的数据收集和挖掘过程中,我们可能希望将网络上的 JSON 数据库快速获取并且插入到本地数据库中。
通常方法就是将 JSON 数据下载,然后对 JSON 数据库进行处理,然后保存。
Spring 有没有提供什么快速的方法进行处理?
其实 Spring 提供了一个 RestTemplate 可以完成数据下载,并且进行在内存中进行对象的转换。
这里我们使用的是 exchange 进行的转换。
我们就可以使用提供的 exchange 方法。
首先我们需要定义:Covid19Current 对象,这个对象必要重要,首先这个对象是 JPA 的对象,同时这个对象也映射了 JSON 数据中的字段。
如果你不希望这样映射的话,那么你需要进行字段的转换。
然后你就可以使用下面的代码进行数据转换和映射:
ResponseEntity responseEntity = restTemplate.exchange("https://covidtracking.com/api/v1/states/current.json",
HttpMethod.GET,
null,
Covid19Current[].class);
Covid19Current[] covid19Currents = responseEntity.getBody();
请注意,我们这里使用的 Get 方法,然后将数据转换到对象 Array 中。