0


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语句达到同样的效果。

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

privateStringmakeOrderByFieldSql(String fieldName,List<String> fields){StringBuilder orderSql =newStringBuilder();
    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();}

使用时,构建:

//构建LambdaQueryWrapperLambdaQueryWrapper<Course> courseLambdaQueryWrapper =newLambdaQueryWrapper<>();//调用方法生成sql语句String orderSql =this.makeOrderByFieldSql("teacher_ids", teacherIds);//使用last函数在查询的最后拼接sql语句
courseLambdaQueryWrapper.in(CourseResource::getTeacherId, resourceIds).last(orderSql);//查询得到结果
courses = courseService.list(courseLambdaQueryWrapper);
标签: mysql 数据库 java

本文转载自: https://blog.csdn.net/GUILTYxc/article/details/132950592
版权归原作者 GUILTYxc 所有, 如有侵权,请联系我们删除。

“MySQL:使用“IN“语句查询时保持顺序”的评论:

还没有评论