web-dev-qa-db-fra.com

Hibernate: comment remplacer un attribut de la classe supérieure mappée

L'entité générique, super classe:

@MappedSuperclass
public abstract class GenericEntity {
    private Integer id;
    public Integer getId() {return id;}
    public void setId(Integer id) {this.id = id;}
}

Le pojo:

@Entity
@Table(name = "POJO_ONE")
@SequenceGenerator(name = "HB_SEQ_POJO_ONE", sequenceName = "SEQ_POJO_ONE", allocationSize = 1)
public class PojoOne extends GenericEntity {

    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "HB_SEQ_POJO_ONE")
    @Column(name = "ID")
    @AttributeOverride(name = "id", column = @Column(name = "ID"))
    private Integer id;

    @Override
    public Integer getId() {return id;}
}

J'essaie d'utiliser Thoses Annotations: @attributeOverride, @ID, ... mais ça ne marche pas. Pouvez-vous m'aider? Je veux remplacer l'attribut "ID" pour spécifier un autre nom de colonne et une séquence de Pojo/Table. Quelle est la meilleure façon de le faire?

16
BasicCoder

Essayez cela, à la place

@MappedSuperclass
public abstract class GenericEntity {
    private Integer id;
    ...

    public Integer getId() {return id;}
    public void setId(Integer id) {this.id = id;}
}


@Entity
@Table(name = "POJO_ONE")
@SequenceGenerator(name = "HB_SEQ_POJO_ONE", sequenceName = "SEQ_POJO_ONE", allocationSize = 1)
@AttributeOverride(name = "id", column = @Column(name = "ID"))
public class PojoOne extends GenericEntity {
    // we should not define id here again
    ...

    @Override
    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "HB_SEQ_POJO_ONE")
    public Integer getId() {return id;}
}
28
Adeel Ansari

Pourquoi ne pas annoter le id de générosité avec @Id? Vous ne devez pas non plus redéfinir id mais mettre la fonction @AttributeOverride(name = "id", column = @Column(name = "ID")) sur la classe plutôt qu'un champ.

Éditer:

Nous utilisons cela dans notre classe de base (package.OurTableGenerator Est notre propre implémentation):

@GeneratedValue ( generator = "ourTableGenerator", strategy = GenerationType.TABLE )
@GenericGenerator ( name = "ourTableGenerator", strategy = "package.OurTableGenerator",
  parameters = { @Parameter ( name = OurTableGenerator.TABLE_PARAM, value = "t_sequence" ),
                 @Parameter ( name = OurTableGenerator.SEGMENT_COLUMN_PARAM, value = "c_entity" ),
                 @Parameter ( name = OurTableGenerator.VALUE_COLUMN_PARAM, value = "c_nextHi" ),
                 @Parameter ( name = OurTableGenerator.INCREMENT_SIZE_COLUMN_PARAM, value = "c_blocksize" ) } )
@Id
@Column(name = "c_uid")
private Long uid;

Cela nous permet de spécifier une taille et une séquence de bloc différents par entité/table.

Pour votre propre générateur de table, vous pouvez sous-classement org.hibernate.id.TableGenerator.

4
Thomas