mysql根据查询结果去排序示例

该SQL语句展示了如何根据查询结果的状态、时间范围和INNER_TYPE_ID进行排序,条件包括当前时间比较和非空内类型ID。
摘要由CSDN通过智能技术生成

 将查询结果作为条件,参与排序

SELECT id,
        `name`,
        start_time    AS startTime,
        end_time      AS endTime,
        `type`,
        inner_type_id AS innerTypeId,
        (
        CASE
        WHEN (start_time > CURRENT_TIMESTAMP()) THEN 0
        WHEN (start_time <= CURRENT_TIMESTAMP() AND end_time >= CURRENT_TIMESTAMP()) THEN 1
        WHEN (end_time < CURRENT_TIMESTAMP()) THEN 2
        END
        )         AS status
        FROM  xxx_xx
        <where>
            del_flag = 0
            <if test="status == 0">
                AND start_time &gt; CURRENT_TIMESTAMP() AND end_time &gt; CURRENT_TIMESTAMP() AND forecast_flag = 1
            </if>
            <if test="status == 1">
                AND start_time &lt;= CURRENT_TIMESTAMP() AND end_time &gt;= CURRENT_TIMESTAMP()
            </if>
            <if test="status == 2">
                AND end_time &lt; CURRENT_TIMESTAMP()
            </if>
            <if test="innerTypeId != null">
                AND inner_type_id = #{innerTypeId}
            </if>
        </where>
        ORDER BY status, sort, start_time DESC

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

JB091

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值