gpt4 book ai didi

JAVA - 通过有效地分组数据将结果集存储在哈希表中

转载 作者:行者123 更新时间:2023-11-29 06:08:16 26 4
gpt4 key购买 nike

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

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()
}

换句话说,结果集会迭代多次,每次都会创建一个新键,以便将剩余的结果集条目与其进行比较。每次删除处理后的条目退出外循环。

由于结果集非常大(每个 List(Object) 也是如此),性能很差(每个键的加载时间非常长)。将 order by 子句附加到查询(以便初步分组数据)并不能缓解问题。

有没有更有效的方法?

谢谢大家

编辑

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>对于 key 因为另一个 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 作为其实例变量的类。非常小心地重写 equals。

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

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com