【Bug】Java HashMap为无序集合

最近在跟进码表功能,由于在某些场景(如:下拉列表)下需要获取有序的数据集合,而负责详细设计的同学并没有将排序功能纳入详细设计。ID、CREATE_TIME考虑到新增、删除等操作不适合用来做排序字段,DICT_CODE 不够自由(元素顺序无法自由调整)。导致功能开发完成后需要新增排序字段以便对查询结果进行排序。

在做详细设计、表设计的时候还是应该尽量了解清楚该功能需要支持的场景。

select dict_type, dict_code, dict_name, language_type, data_version, status, sort from dictionary where dict_type='dict_type' order by sort asc

通过添加排序字段,SQL查询的结果已经是有序的了。由于业务需要,需要对查询结果进行过滤,结果过滤后的数据在界面显示居然是无序的。排查代码发现,由于之前并不需要考虑排序,所以代码中使用的是HashMap保存中间结果,新增排序字段后并未对此处进行调整,而HashMap是无序集合,导致最终显示的数据是无序的。

HashMap调整为LinkedHashMap,结果显示正常。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值