多层排序

    排序时不止根据一个因素的大小来排,而是有多个因素,每个因素之间有优先级,比如说给一个班的学生排序,高的排前面,如果一样高的则体重大的排前,如果身高体重一样的则年龄大的排前。
    可以用一个结构存一个学生的信息:身高、体重、年龄,然后重载小于号'<' 和大于号'>',这样重载:

struct Student{

int height, weight, age;
bool operator < (const Student& other){
if(this->height !=other.height)
return    this->height < other.height;
else{
if(this->weight != other.weight)
return  this->weight < other.weight;
else{
if( this->age != other.age )
return  this->age < other.age;
}
}  
}

bool operator > (const Student& other){
if(this->height !=other.height)
return    this->height > other.height;
else{
if(this->weight != other.weight)
return  this->weight > other.weight;
else{
if( this->age != other.age )
return  this->age > other.age;
}
}  
}

};




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在MyBatis中,如果你想在查询结果中进行多层排序(即多个排序条件),你可以使用`ORDER BY`子句,并且可以组合使用`ASC`(升序)和`DESC`(降序)关键字。以下是写多层`ORDER BY`的步骤: 1. **基础语法**: 如果只有一个排序条件,你可以在SQL映射文件的`select`语句后直接添加`ORDER BY`,如下: ```xml <select id="selectAllWithOrder" resultType="YourEntity"> SELECT * FROM your_table ORDER BY column1 ASC </select> ``` 2. **多条件排序**: 如果有多个排序条件,可以使用逗号分隔,例如先按`column1`排序,再按`column2`排序,如果`column1`相同则降序排列: ```xml <select id="selectAllMultiOrder" resultType="YourEntity"> SELECT * FROM your_table ORDER BY column1 ASC, column2 DESC </select> ``` 3. **动态排序**: 如果排序条件依赖于传入的参数,可以使用动态SQL标签如`<if>`或`<choose>`来构造动态的`ORDER BY`: ```xml <select id="dynamicOrderBy" resultType="YourEntity"> SELECT * FROM your_table <choose> <when test="sortField == 'column1'"> ORDER BY column1 ${sortOrder} </when> <when test="sortField == 'column2'"> ORDER BY column2 ${sortOrder} </when> <!-- 其他条件... --> </choose> </select> ``` 这里`${sortOrder}`应该是`ASC`或`DESC`,可以通过参数传递。 4. **使用Criteria API**: 如果你使用的是MyBatis的Criteria API,可以创建一个`Order`对象数组来表示多层排序: ```java List<Order> orders = new ArrayList<>(); orders.add(Order.asc("column1")); orders.add(Order.desc("column2")); CriteriaQuery<MyEntity> criteria = ...; criteria.orderBy(orders); ``` 记得在每个情况下,`your_table`应替换为实际的表名,`YourEntity`是对应的数据实体类名,`column1`和`column2`是你要排序的列名,`sortField`和`sortOrder`是传入的动态参数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值