我正在用Spring Boot编写REST API。因此,我按姓名获得员工。我正在传递Pageable
参数进行排序,问题是方向被忽略了。因此,Spring总是对asc
神经desc
进行排序,这是默认行为。我不知道我在做什么错。
我需要补充一点,一般来说排序是可行的,因为如果我不将chrValue
作为sort
参数传递,则会得到类似存储在数据库中的项。
请求:
http://localhost:8080/dimensionAttributeValues/search/findDimensionAttributeValueByDimensionAttributeDimensionAttributeID?dimensionAttributeId=1&page=0&size=1&sort=chrValue&chrValue.dir=desc
存储库:
@RepositoryRestResource(collectionResourceRel = "dimensionAttributeValue", path = "dimensionAttributeValues")
@CrossOrigin(exposedHeaders="Access-Control-Allow-Origin")
public interface DimensionAttributeValueRepository extends PagingAndSortingRepository<DimensionAttributeValue, Long> {
Page<DimensionAttributeValue> findDimensionAttributeValueByDimensionAttributeDimensionAttributeID(@Param(value = "dimensionAttributeId") long dimensionAttributeId, Pageable pageable);
Page<DimensionAttributeValue> findDimensionAttributeValueByMasterDataMasterDataIDAndDimensionAttributeDimensionAttributeID(@Param(value = "masterDataId") long masterDataId, @Param(value = "dimensionAttributeId") long dimensionAttributeId, Pageable pageable);
Page<DimensionAttributeValue> findDimensionAttributeValueByDimensionAttributeDimensionDimensionIDOrDimensionAttributeDimensionAttributeIDOrderByChrValue(@Param(value="dimensionID") long dimensionID, @Param(value = "dimensionAttributeID") long dimensionAttributeID, Pageable pageable);
Page<DimensionAttributeValue> findAllByDimensionAttributeDimensionAttributeIDAndChrValueStartingWith(@Param(value = "dimensionAttributeId") long dimensionID, @Param(value = "chrValue") String chrValue, Pageable pageable);
}
实体:
@Entity
@Table(name = "DimensionAttributeValue")
public class DimensionAttributeValue {
@Id
@GeneratedValue
@Column(name = "DimensionAttributeValue_ID")
private long dimensionAttributeValueID;
@ManyToOne
@JoinColumn(name = "DimensionAttribute_ID")
private DimensionAttribute dimensionAttribute;
@ManyToOne
@JoinColumn(name = "MasterData_ID")
private MasterData masterData;
@Column (name = "ChrValue")
private String chrValue;
@Column (name = "IntValue")
private Long intValue;
@Column (name = "DecValue")
private Double decValue;
@Column (name = "DatValue")
private String datValue;
@Column (name = "BlnValue")
private Boolean blnValue;
@ManyToOne
@JoinColumn (name = "LnkValue")
private DimensionAttributeValue lnkValue;
@ManyToOne
@JoinColumn (name = "LstValue")
private DimensionAttributeList lstValue;
@Column (name = "StartDate")
private Date startDate;
// [...]
}
有什么想法吗?谢谢!
答案 0 :(得分:2)
尝试使用此URL。
http://localhost:8080/dimensionAttributeValues/search/findDimensionAttributeValueByDimensionAttributeDimensionAttributeID?dimensionAttributeId=1&page=0&size=1&sort=chrValue,desc
。
这将按降序对数据进行排序。