这是一个有争议的问题。如果你不想创建单独的dto,有几种方法可以做到这一点。这取决于您要使用的数据访问方式:
使用Spring数据JPA可以在投影中返回实体。你只需要一个额外的构造函数添加到您的实体:
public interface UserRepository extends JpaRepository<User, Long> {
@Query("select new User(u.id,u.name) from User u")
List<User> findAllUserItems();
}
或者相同的使用JPA EntityManger:
public List<User> findAllUserItems() {
return entityManager.createQuery("select new User(u.id,u.name) from User u", User.class)
.getResultList();
}
如果你想知道不必要的空字段,并且您使用杰克逊,可配置忽略空字段。春季启动:
spring.jackson.default-property-inclusion=non_null
或者与Java的配置:
@Bean
public Jackson2ObjectMapperBuilder objectMapperBuilder() {
Jackson2ObjectMapperBuilder builder = new Jackson2ObjectMapperBuilder();
builder.serializationInclusion(JsonInclude.Include.NON_NULL);
return builder;
}
或者不春天启动项目:
@Configuration
@EnableWebMvc
public class WebConfig extends WebMvcConfigurerAdapter {
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
converters.add(converter());
}
@Bean
public HttpMessageConverter converter() {
ObjectMapper objectMapper = new ObjectMapper();
objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
return new MappingJackson2HttpMessageConverter(objectMapper);
}
}
另外,如果你打算使用Hibernate的Session。为了直接映射到DTO你可以使用AliasToBeanResultTransformer
:
public List<UserDto> findAllUserItems() {
return session.createQuery("select u.id as id,u.name as name from User u")
.setResultTransformer(Transformers.aliasToBean(UserDto.class))
.list();
}
我觉得是更优雅,如果你创建你的API另一层在那里你可以提出一个要求用户通过ID只得到部分值,不具有意义,如果你获取所有值仅用于从DTO响应中获取一个值。 –