Sau*_*mar 5 java lambda java-8 spring-data spring-data-jpa
我正在使用Spring Data JPA。
我的控制器看起来像以下
@RequestMapping(value = "/pages/{pageNumber}", method = RequestMethod.GET, consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<Page<User>> paginatedUser(@PathVariable final Integer pageNumber)
{
final PageRequest request = new PageRequest(pageNumber - 1, DEFAULt_PAGE_SIZE, Sort.Direction.DESC, "startTime");
return new ResponseEntity<>(userRepository.findAll(request), HttpStatus.OK);
}
Run Code Online (Sandbox Code Playgroud)
现在我决定发送一个PageDTO对象而不是Page对象来限制发送的内容,是否有任何方法可以使用Java 8将Page转换为PageDTO。
我看到Page是从派生的,Iterable
所以我想我可以执行以下操作,但不确定如何将其与PageDTO和UserDTO放在一起。
StreamSupport.stream(userRepository.findAll(request).spliterator(),false)
Run Code Online (Sandbox Code Playgroud)
有什么有效的java 8方法可以做到这一点。
我想出了这个解决方案
@RequestMapping(value = "/pages/{pageNumber}", method = RequestMethod.GET, consumes = MediaType.APPLICATION_JSON_VALUE, produces = MediaType.APPLICATION_JSON_VALUE)
public ResponseEntity<PageDTO> paginatedUser(@PathVariable final Integer pageNumber)
{
final PageRequest request = new PageRequest(pageNumber - 1, DEFAULt_PAGE_SIZE, Sort.Direction.DESC, "startTime");
final Page<User> page = userRepository.findAll(request);
return new ResponseEntity<>(new PageDTO(page, StreamSupport.stream(page.getContent().spliterator(), true).map(UserDTO::new)
.collect(Collectors.toList())), HttpStatus.OK);
}
public class PageDTO {
private int beginIndex;
private int currentIndex;
private int endIndex;
private List<?> entities;
public PageDTO(final Page<?> page, final List<?> entities) {
this.entities = entities;
this.currentIndex = page.getNumber() + 1;
this.beginIndex = Math.max(1, currentIndex - 5);
this.endIndex = Math.min(beginIndex + 10, page.getTotalPages());
}
Run Code Online (Sandbox Code Playgroud)
是否想知道是否还有另一种有效的方法?
我知道这是一个老问题,但我遇到了同样的问题,我想为可能感兴趣的任何人提供可能的解决方案。这是我发现对我的代码有帮助的内容:https : //github.com/pkainulainen/spring-data-jpa-examples/blob/master/query-methods/src/main/java/net/petrikainulainen/springdata/ jpa/todo/TodoMapper.java
我还使用了JpaRepository对数据进行分页,以便 DTO 页面具有相同的参数(页码、大小等)。这是我的存储库:
@Repository
public interface Repository extends JpaRepository<Entity, Integer> {
/**
* Name the method according to what query you need to execute
* e.g. findAll --> return all the rows that satisfy the following conditions,
* ByUsername --> username is a field in entity class,
* @param pageable: pagination is applied on the data.
* @return
*/
public Page<Entity> findAllByUsername(String username, Pageable pageable);
}
Run Code Online (Sandbox Code Playgroud)
这是我进行映射的方法:
public Page<EntityDTO> findByUsername(String username, Pageable pageable){
Page<Entity> entityPage = entityRepository.findAllByUsername(username, pageable);
List<EntityDTO> dtos = mapper.entityToEntityDTOs(entityPage.getContent());
return new PageImpl<>(dtos, pageable, entityPage.getTotalElements());
}
Run Code Online (Sandbox Code Playgroud)
还有我的Mapstruct映射器:
import org.mapstruct.factory.Mappers;
/**
* Mapper for converting entity to DTO.
*/
@Mapper(componentModel = "spring", uses = {})
public interface Mapper {
/**
* The interface declares a member INSTANCE, providing clients access to the mapper implementation,
* which is the file target\generated-sources\com\company\springapp\dto\mappers\MapperImpl.java
* (automatically generated when compiling the project).
*/
AuditMapper INSTANCE = Mappers.getMapper( Mapper.class );
/**
* Convert entity to DTO.
* Mappings are used to 'bind' entity fields to DTO fields (for the mapper's implementation).
* @param entity
* @return
*/
@Mappings({
@Mapping(source = "id", target = "id"),
@Mapping(source = "username", target = "dtoUsername"),
@Mapping(source = "action", target = "dtoAction")
})
public EntityDTO entityToEntityDTO(Entity entity);
/**
* Convert entities' list to DTOs' list.
* @param entities
* @return
*/
public List<EntityDTO> entitiesToEntityDTOs(List<Entity> entities);
}
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
4547 次 |
最近记录: |