对不起,我的英语。我有个问题。我想对我的列表进行排序(取自数据库,可能无法在查询中排序),但是我不知道用户选择的参数是什么参数。这按desc中的名字和姓氏排序,但是如何创建动态名字呢?我做了很多尝试,但是失败了。感谢您的帮助
myList.sort(Comparator.comparing(DTO::getName).thenComparing(DTO::getLastName).reversed());
要根据用户参数创建自定义的订单,我建议类似:
1-创建可能的排序顺序的枚举,该顺序将由用户查询中的参数填充,例如,我有3个顺序BY_ID, BY_NAME, BY_LAST_NAME
。
2-然后创建此枚举的列表;
3-然后创建一个映射,其中的键是上面的枚举,而值是一个比较器。
4-填充地图。
5-从您在(2)中拥有的订单列表和在(3)中的映射得出一个简化的最终比较器。
6-按该最终比较器对列表进行排序。
public enum SortOrder {
BY_ID,
BY_NAME,
BY_LAST_NAME;
}
public static void main(String[] args) {
/**dummy objects for test purposes**/
DTO firstDTO = new DTO();
firstDTO.setId(1);
firstDTO.setName("John");
firstDTO.setLastName("Doe");
DTO secondDTO = new DTO();
secondDTO.setId(2);
secondDTO.setName("John");
secondDTO.setLastName("Doe");
DTO thirdDTO = new DTO();
thirdDTO.setId(2); // the id is repeated
thirdDTO.setName("Alice");
thirdDTO.setLastName("Bob");
final List<SortOrder> sortOrders = createSortOrdersFromInputParams(/*the params passed as args*/);
final List<DTO> myList = Arrays.asList(firstDTO, secondDTO, thirdDTO); // your list that is supposed to come from a DB
final Map<SortOrder, Comparator<DTO>> map = new EnumMap<>(SortOrder.class);
final Comparator<DTO> defaultComparator = Comparator.nullsLast(Comparator.comparing(DTO::getId)); // you'all always need a default comparator , say by ID
map.put(SortOrder.BY_ID, defaultComparator);
map.put(SortOrder.BY_NAME, Comparator.nullsLast(Comparator.comparing(DTO::getName)));
map.put(SortOrder.BY_LAST_NAME, Comparator.nullsLast(Comparator.comparing(DTO::getLastName)));
final Comparator<DTO> finalComparator = sortOrders.stream()
.map(map::get)
.filter(Objects::nonNull)
.reduce(Comparator::thenComparing)
.orElse(defaultComparator);
myList.sort(finalComparator);
System.out.println(myList);
}
private static List<SortOrder> createSortOrdersFromInputParams(/*params passed as args*/) {
return Arrays.asList(SortOrder.BY_ID, SortOrder.BY_NAME, SortOrder.BY_LAST_NAME);
}
我希望这能回应您的情况。