JAVA实现多重排序

是这样的原先呢我们的列表会根据某一个字段升序或者降序 但是现在用户有新需求要求我们能够多重排序,对于sql我们知道其实这是很简单的,接下来直接上代码

public class CustomerDTO {

    private List<SortField> sortFields;


}

 

@Data
public class SortField {
    private String fieldName;
    private String order;

    // Getters and Setters
}

 当然也可以这么写 但是这样会有sql注入的问题为了安全咱还是多写一点趴

<foreach collection="customerDTO.sortFields" item="sortField" separator=",">
				${sortField.fieldName} ${sortField.order}
			</foreach>

 

 

<if test="customerDTO.sortFields != null and customerDTO.sortFields.size() > 0">
			ORDER BY
			<foreach collection="customerDTO.sortFields" item="sortField" separator=",">
				<choose>
					<when test="sortField.fieldName == 'totalPayNum'">totalPayNum ${sortField.order}</when>
  
				</choose>
			</foreach>
		</if>
		<if test="customerDTO.sortFields == null or customerDTO.sortFields.size() == 0">
			ORDER BY loginDate DESC <!-- 默认排序 -->
		</if>

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值