I'm trying to get the resultset as a map and I'm successfully able to get it into a map. But the map keys are not as per the order of select query
Please check the code:
String queryString = "SELECT T1.COLUMN_11, T1.COLUMN_12, T2.COLUMN_21, T2.COLUMN_22 FROM MYSCHEMA.TABLE1 T1 INNER JOIN MYSCHEMA.TABLE2 T2 ON T1.SOME_COLUMN = T2.SOME_OTHER_COLUMN";
Query query = entityManager.createNativeQuery(queryString)
.unwrap(org.hibernate.query.Query.class)
.setResultTransformer(AliasToEntityMapResultTransformer.INSTANCE);
List<Map<String, Object>> resultSet = queryEx.getResultList();
Now as per expectation the List<Map<String, Object>> resultSet
should look something like below
[
{
"COLUMN_11": "VALUE11",
"COLUMN_12": "VALUE12",
"COLUMN_21": "VALUE21",
"COLUMN_22": "VALUE22"
},
...............
]
But the colums are jumbled something like below
[
{
"COLUMN_21": "VALUE21",
"COLUMN_12": "VALUE12",
"COLUMN_11": "VALUE11",
"COLUMN_22": "VALUE22"
},
...............
]
Is there anyway I can retain the order as in select statement ?
PS: Can't create a model to hold the resultSet values as query is dynamic. So "HAD TO" use map only.
Try to remove .setResultTransformer(AliasToEntityMapResultTransformer.INSTANCE)
. I'm not an Hibernate expert but most JPA implementation return a list of Object arrays by default that preserve the order of the columns.
An alternative would be to implement your own transformer where you use a LinkedHashMap instead of a HashMap. AliasToEntityMapResultTransformer uses HashMap.