MySQL:使用“IN“语句查询时保持顺序

场景

当我在MySQL中使用IN语句进行查询时
例如SELECT * FROM Course WHERE teacher_id in ("6553","2145","3162"),从课程表里使用教师id查询记录,这时我希望返回的记录是按("6553","2145","3162")的顺序,但是发现并不是,而是("2145","3162","6553")的顺序,进行了排序。

如何解决?

可以使用ORDER BY FIELD语句。
SELECT * FROM Course WHERE teacher_id in ("6553","2145","3162") ORDER BY FIELD(tracher_id,"6553","2145","3162"),其中tracher_id指定排序的字段,之后给出顺序,返回的结果即可满足按IN中指定的顺序排序。

MyBatisPlus

在MyBatis或MyBatisPlus中,可以手动拼接sql语句达到同样的效果。

方法(传入字段名和字段列表):

private String makeOrderByFieldSql(String fieldName, List<String> fields) {

    StringBuilder orderSql = new StringBuilder();
    orderSql.append("ORDER BY FIELD(").append(fieldName).append(",");
    for (String field : fields) {
        orderSql.append("\"").append(field).append("\"").append(",");
    }
    //去除最后一个 ",",加上括号
    orderSql.deleteCharAt(orderSql.length() - 1).append(")");
    return orderSql.toString();
}

使用时,构建:

//构建LambdaQueryWrapper
LambdaQueryWrapper<Course> courseLambdaQueryWrapper = new LambdaQueryWrapper<>();
//调用方法生成sql语句
String orderSql = this.makeOrderByFieldSql("teacher_ids", teacherIds);
//使用last函数在查询的最后拼接sql语句
courseLambdaQueryWrapper.in(CourseResource::getTeacherId, resourceIds).last(orderSql);
//查询得到结果
courses = courseService.list(courseLambdaQueryWrapper);
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
MySQL的IN查询语句是一种用于在一个字段中匹配多个值的查询方式。它可以在WHERE子句中使用,用于筛选出字段值与给定值列表中任意一个匹配的记录。 IN查询语句的执行顺序如下所示: 1. 首先,MySQL会对IN查询语句中的值列表进行排序,以提高查询性能。 2. 接下来,MySQL会根据索引或表扫描的方式来查找匹配的记录。如果存在适当的索引,MySQL使用索引来加速查询。否则,它将执行全表扫描来查找匹配的记录。 3. 最后,MySQL会返回匹配的记录。 在执行IN查询语句MySQL会根据查询处理阶段的分析来确定最佳的查询执行计划。这包括选择合适的索引、使用缓存等优化策略,以提高查询性能。 引用\[1\]提供了关于MySQL语句执行顺序查询处理阶段的分析,可以作为参考。引用\[2\]中介绍了在MySQL查询当前正在执行的SQL语句和其他相关线程的方法,可以用于监控和调试。引用\[3\]提供了一个用于统计类似SQL语句查询次数的工具,可以用于分析和优化查询性能。 总结起来,MySQL的IN查询语句是一种用于匹配多个值的查询方式,它的执行顺序查询处理阶段的分析可以参考引用\[1\]、\[2\]和\[3\]中的内容。 #### 引用[.reference_title] - *1* *2* *3* [Mysql IN语句查询](https://blog.csdn.net/weixin_27070451/article/details/115845301)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值