向HashMap、LinkedHashMap插入100000条数据效率比较


  • 在向HashMap插入数据时,发现Resultset返回的数据是正常顺序,但是插入HashMap后数据出现乱序,因此后续用LinkedHashMap解决数据乱序问题。
  • LinkedHashMap保存了记录的插入顺序,在用Iterator遍历LinkedHashMap时,先得到的记录肯定是先插入的。也可以在构造时带参数,按照应用次数排序。
        List<Map<String, Object>> list = new ArrayList<>();     存放结果(表数据)
        String sql = "select * from " + table + " limit 100000";

        //获取开始时间
        long startTime = System.currentTimeMillis();

        ResultSet rs = stmt.executeQuery(sql);   //调用sql

            // 表数据遍历
            ResultSetMetaData md = rs.getMetaData();
            int columnCount = md.getColumnCount();
            while (rs.next()) {
                Map<String, Object> rowData = new LinkedHashMap<>();   // 1 LinkedHashMap
                //Map<String, Object> rowData = new HashMap<>();       // 2 HashMap
                for (int i = 1; i <= columnCount; i++) {
                    rowData.put(md.getColumnName(i), rs.getObject(i));
                }
                list.add(rowData);
            }

            //获取结束时间
            long endTime = System.currentTimeMillis();

            //输出程序运行时间
            double spendTime = (endTime - startTime)/1000.0;
            System.out.println("查询时间:" + spendTime + "s");

LinkedHashMap情况下,多次测试插入数据的运行时间

在这里插入图片描述

HashMap情况下,多次测试插入数据的运行时间

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值