最近公司新来了一个小伙伴,问了磊哥一个比较“奇怪”的问题,这个问题本身的难度并不大,但比较“隐蔽”,那究竟是什么问题呢?接下来我们一起来看。
起因
最近公司的系统要增加一个新的列表展示功能,功能本身难度并不大,但遇到了一个很“可怪”的问题。小伙伴在执行查询列表时,明明已经使用了 order by 进行排序了,但最终查询出来的数据却还是乱的。
预期中的(正确)结果:
现实中的(非预期)结果:
那到底是哪里出现了问题呢?
问题展示
为了方便展示,我把复杂的业务程序简化成了以下代码:
import java.util.HashMap; public class App { public static void main(String[] args) { HashMap<String, Object> result = getList(); result.forEach((k, v) -> { System.out.println(k + ":" + v); }); } // 查询方法(简化版) public static HashMap<String, Object> getList() { HashMap<String, Object> result = new HashMap<>(); // 最终返回的结果集 // 伪代码:从数据库中查询出了数据,然后对数据进行处理之后,存到了 for (int i = 1; i <= 5; i++) { result.put("2022-10-" + i, "hello java" + i); } return result; } }