我用这个东西来获取一个列表>,这对于操作“结果集”这样的数据非常有趣。 我的方法是: requeteSQL.setResultTransformer(AliasToEntityMapResultTransformer.INSTANCE);
当我使用 sqldevelopper 执行此查询时,我得到了示例 |领域 1 |场2 1 号线 |值 1 |值 2
但是我的 map 顺序不正确? 如何修复此错误?为什么我的 map 按此顺序 Field2 = Value2、Field1 = Value1 ?
最佳答案
因为它是 HashMap ,你怎么能期望订单检索,如果想要订单检索请实现你自己的 ResultTransformer 它将返回 LinkedHashMap 例如
public class AliasToEntityOrderedMapResultTransformer extends AliasedTupleSubsetResultTransformer {
public static final AliasToEntityOrderedMapResultTransformer INSTANCE = new AliasToEntityOrderedMapResultTransformer();
/**
* Disallow instantiation of AliasToEntityOrderedMapResultTransformer .
*/
private AliasToEntityOrderedMapResultTransformer () {
}
/**
* {@inheritDoc}
*/
public Object transformTuple(Object[] tuple, String[] aliases) {
/* please note here LinkedHashMap is used so hopefully u ll get ordered key */
Map result = new LinkedHashMap(tuple.length);
for ( int i=0; i<tuple.length; i++ ) {
String alias = aliases[i];
if ( alias!=null ) {
result.put( alias, tuple[i] );
}
}
return result;
}
/**
* {@inheritDoc}
*/
public boolean isTransformedValueATupleElement(String[] aliases, int tupleLength) {
return false;
}
/**
* Serialization hook for ensuring singleton uniqueing.
*
* @return The singleton instance : {@link #INSTANCE}
*/
private Object readResolve() {
return INSTANCE;
}
}
顺便说一句,您的逻辑不应取决于结果 map 中出现的键的顺序。
关于java - 如何使用 AliasToEntityMapResultTransformer 获取订单映射?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15108267/