Mysql
 sql >> Database >  >> RDS >> Mysql

Mybatis:mappa parte dell'SQL su HashMap all'interno di POJO

Dopo molti tentativi, ho trovato la soluzione come segue:

POJO:

private int id;
private String name;
private String surname;
private HashMap<String, Object> aditionalColumns;

// getters & setters

Mappatore di MyBatis:

<resultMap id="BaseResultMap" type="Person" automapping="true">
  <id column="id" property="id"/>
  <association
      property="aditionalColumns"
      resultMap="aditionalColumnsMapper" 
      columnPrefix="calculated_" />
</resultMap>

<resultMap id="aditionalColumnsMapper" type="map" autoMapping="true"/>

In questo caso, la mia HashMap di colonne aggiuntive sarebbe simile a questa dopo la mappatura:

{column_1=value1, column_2=value2}

Nota:non sapevo di quante colonne avevo bisogno, se sai esattamente quante ne hai bisogno e non cambierà, puoi mappare solo le tue colonne cambiando il secondo resultMap come segue:

<resultMap id="aditionalColumnsMapper" type="map">
    <result column="calculated_column_1" property="calculated_column_1"/>
    <result column="calculated_column_2" property="calculated_column_2"/>
</resultMap>