MySQL问题篇2:关于IN字段不按照顺序返回问题

一、发现问题

数据库表结构如下:

其查询语句如下:

SELECT
	*
FROM
	department
WHERE
	department_id IN (5,4,2,3,1)

其返回结果如下: 

 

到此处我们发现了问题,其中我in写的是(5,4,2,3,1),其返回结果顺序为1,2,3,4,5,如果我们就是想按照我们in的顺序来返回数据的顺序,其显然的不对的。 

二、解决方案 

无论因为何种问题,导致我们无法按照有规则的字段进行排序返回结果,只能通过in中顺序来返回的结果,我们只能使用自定义排序

MySQL中ORDER BY的field()函数,可以用来对SQL中查询结果集进行指定顺序排序。

其一般语法为:field(字段,value,value,.......)

来看上面的解决方案:

SELECT
	*
FROM
	department
WHERE
	department_id IN (5, 4, 2, 3, 1)
ORDER BY
	FIELD(department_id, 5, 4, 2, 3, 1)

其结果集:
 

到这里基本的理论就完事了,但是实际开发中我们使用的是springboot,其使用的是mybatis与mybatisplus,而且也不可能正好的就是写死id的值,那我们怎么办呢? 

三、在 mybatis中的应用

其在mapper中可以有类似的处理,使用foreach进行循环,原理懂即可

 <select id="selectDepartmentsInOrder" resultType="com.example.Department">
        SELECT department_id, name
        FROM department
        WHERE department_id IN
        <foreach item="id" collection="list" open="(" separator="," close=")">
            #{id}
        </foreach>
        ORDER BY FIELD(department_id,
        <foreach item="id" collection="list" separator=",">
            #{id}
        </foreach>
        )
    </select>

如果是在mybatisplus中就要复杂一点了 

 List<Integer> departmentIds = Arrays.asList(5, 4, 2, 1, 3);
//按照5,4,1,2,3
 String idStr = StrUtil.join(",", departmentIds );
    List<DepartmentDTO> departmentDTOS = departmentService.query()
            .in("id",ids)
            .last("order by field(id,"+idStr+")").list()

首先我们要干的事情是拼接list列表中的id,然后在mbp中没有关于field函数,所以我们只能用last来手动写查询语句,然后拼接 。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值