我想在哈希表中存储来自查询执行的结果集。
哈希表是这样的

Map<List<String>,List<Object>>

哪里
List<String>, the hash table key, is a subset of the extracted fields
Object is a Java object corresponding to a database tuple (all fields)

因此,首先,必须对数据进行分组,以便创建每个键并对共享该键的所有项进行分组。
与我当前方法相关的伪代码是:
while(iterate){
     while(rs.next){
          if(key is empty)
                // build REFERENCE KEY and delete rs entry
          else
                // build key for i-th rs entry and compare it with the REFERENCE key.
                   Eventually, get data and delete rs entry
     }
     rs.beforeFirst()
}

换句话说,结果集被多次迭代,每次创建一个新的键,以便将ramaining结果集条目与之进行比较。每次删除已处理的条目以退出外部循环。
由于结果集非常大(以及每个列表(对象)),因此性能很差(每个键的加载时间非常长)。
在查询中追加ORDERBY子句(以便对数据进行初步分组)并不能缓解问题。
有没有更有效的方法?
谢谢大家。
编辑
Input ResultSet
 ---------------------------------------------------------------
| Field1 | Field2 | Field3 | Field4 | Field5 | Field6 | Field7 |
---------------------------------------------------------------
|    X   |    A   | val1_3 | val1_4 | val1_5 | val1_6 | val1_7 |
|    X   |    A   | val2_3 | val2_4 | val2_5 | val2_6 | val2_7 |
|    Y   |    B   | val3_3 | val3_4 | val3_5 | val3_6 | val3_7 |
|    Z   |    C   | val4_3 | val4_4 | val4_5 | val4_6 | val4_7 |
|    Y   |    D   | val5_3 | val5_4 | val5_5 | val5_6 | val5_7 |
----------------------------------------------------------------

Key_Fields : [Field1, Field2]

Output Map
-----------------------------------
|   KEY  |     VALUE              |
-----------------------------------
| [X,A]  |   [Object1, Object2]   |
| [Y,B]  |   [Object3]            |
| [Z,C]  |   [Object4]            |
| [Y,D]  |   [Object5]            |
-----------------------------------

我使用List<String>作为键,因为另一个ResultSet可以有不同长度的Key_Fields
这里是我当前耗时的Java代码
while(itera){

            key = new ArrayList<String>();
            values = new ArrayList<AbstractClass>();

            while(rs.next()){

                if(key.isEmpty()){
                     // build REFERENCE KEY
                     // add first OBJECT to List<AbstractClass>
                     // delete this data from ResultSet
                }
                else{
                    // Build KEY_TO_BE_COMPARED
                    List<String> row_to_be_compared = new ArrayList<String>();
                   // If this key equals to REFERENCE KEY
                    if(row_to_be_compared.equals(key)){
                        AbstractClass value_object = new AbstractClass();
                        ...
                        rs.deleteRow();
                    }
                    // ORDERBY clause in query ensures that, if keys don't match, then all objects related to REFERENCE KEY have been collected
                    else{
                        break;
                    }
                }
            }

            rs.beforeFirst();

            map.put(key, values);

            if(!rs.next() || items_loaded==max_hash_size)
                itera = false;
            else
                rs.beforeFirst();
            }
        }

最佳答案

而不是使用列表作为键。使用List作为其实例变量的类。超驰等于非常小心。

关于java - JAVA-通过有效分组数据将结果集存储在哈希表中,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/40017190/

10-13 01:38