LinkedHashMap的一个应用场景

场景描述:将导入系统的Excel数据显示在页面上,其中Excel列名、列数都不确定,要求页面上显示数据排序跟导入的Excel中数据排序一样。

例如如下的Excel

Tiguan
系列
Santana系列民用Lamando系列民用总计Lavida
系列特种
Touran
系列特种
Santana
系列特种
总计
        

解决方案:数据库中用JSON格式存储这种数据

遇到的问题:存储的JSON数据跟Excel中数据顺序不一致,导致页面显示与Excel不一致

产生问题的原因:调试发现解析Excel数据到JSON格式中使用了HashMap来存储Excel中数据,由于HashMap是无序的,当我们把HashMap转换成JSON数据时,数据顺序不固定,导致存储的JSON数据顺序与Excel中数据顺序不一致。

问题解决:将HashMap换成LinkedHashMap,LinkedHashMap保存了记录的插入顺序,在用Iterator遍历LinkedHashMap时,先得到的记录肯定是先插入的。

至此问题得以完美解决。

转载于:https://my.oschina.net/yimozhen/blog/375308

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值