使用Spring Data JPA和Spring Data REST的Spring Boot 2.0.1.RELEASE项目。似乎忽略了REST端点中的sort
参数(但是相同的存储库方法在单元测试中起作用)。存储库如下:
@RepositoryRestResource(collectionResourceRel = "orders", path = "orders")
public interface OrderRepository extends PagingAndSortingRepository<OrderEntity, Integer>, OrderRepositoryExtended {
@Query(value = "FROM OrderEntity a WHERE "
+ " (a.orderDateTime BETWEEN :dateFrom AND :dateTo) AND"
+ " ("
+ " :searchTerm IS NULL OR"
+ " (LOWER(a.customer.companyName) LIKE '%' || LOWER(:searchTerm) || '%') OR"
+ " (LOWER(a.orderCode) LIKE '%' || LOWER(:searchTerm) || '%')"
+ " )"
)
Page<OrderEntity> findByOrderDateTimeBetweenAndSearchTerm(
@RequestParam(name = "dateFrom")
@Param("dateFrom")
@DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME)
LocalDateTime dateFrom,
@RequestParam(name = "dateTo")
@Param("dateTo")
@DateTimeFormat(iso = DateTimeFormat.ISO.DATE_TIME)
LocalDateTime dateTo,
@RequestParam(name = "searchTerm")
@Param("searchTerm")
String searchTerm,
Pageable pageable);
}
实体(编辑)如下:
@Entity
@Table(name = "T_ORDERS")
@Data @NoArgsConstructor
@Cacheable(false)
public class OrderEntity {
@Id
@GeneratedValue(strategy= GenerationType.AUTO, generator = "native")
@GenericGenerator(name = "native", strategy = "native")
@Column(name = "ID_ORDER")
@JsonProperty("id_order")
private int id;
@Column(name = "DATE_ORDER")
@JsonProperty("date_order")
private LocalDateTime orderDateTime;
}
当我尝试使用导出的REST端点调用它时,例如:
sort
参数将被忽略,因为您可以在生成的查询中看到(为清晰起见而编辑):
select orderentit0_.id_order as id_order1_21_
...
from t_orders orderentit0_
cross join t_customers customeren1_
where
orderentit0_.id_customer=customeren1_.id_customer and
(orderentit0_.date_order between ? and ?) and
(? is null or lower(customeren1_.company_name) like concat('%'
lower(?)
'%') or lower(orderentit0_.order_code) like concat('%'
lower(?)
'%')) limit ?
我已经尝试过简化WHERE表达式去除LIKE条件,但没有运气。
谢谢!
您的财产的“导出”名称是date_order
。它应该以这种方式使用,不仅在json请求中,而且在请求参数中。
@Column(name = "DATE_ORDER")
@JsonProperty("date_order")
private LocalDateTime orderDateTime;
试试这种方式:
(sort = date_order)