Can properties mapped in hbm.xml be transient?

12,864

Solution 1

Unmapped/Transient properties are not saved by hibernate.

Hibernate understands the significance of standard java transient modifiers - but also allows you to annotate properties as transient using the @Transient annotation, if you so choose... Or just leave the field out of your mapping file altogether.

In your case, you probably will NOT need to do anything special, hibernate should simply "do the right thing", by ignoring unmapped fields.

So : the lesson learned here -

If only using hbm.xml

1) Unmapped properties are not saved by hibernate - they are effectively transient.

If using POJOs

2) Hibernate will ignore saving "@Transient" annotated variables :

@Transient
int ignored=0;

3) Hibernate will also ignore saving variables with standard "transient" modifiers :

private transient int ignored =0;

See http://docs.jboss.org/hibernate/annotations/3.5/reference/en/html_single/ for an excellent explanation of this.

Solution 2

It looks like Hibernate will not persist a field with the transient keyword, regardless of what other annotations you have.

The separate @Transient annotation will allow you to direct Hibernate to ignore a non-transient field for persistence, but I don't think it's possible to do the opposite of having Hibernate persist a transient field.

Similar discussion here:

JPA - using annotations in a model

Annotation @Basic to transient variables

The most relevant quote via above, from JPA 2.0 spec: "Mapping annotations must not be applied to fields or properties that are transient or @Transient."

Share:
12,864
Konrad Garus
Author by

Konrad Garus

Quality nut. So disappointed with "good enough" and "I don't care I'm too busy chasing my tail".

Updated on June 29, 2022

Comments

  • Konrad Garus
    Konrad Garus almost 2 years

    Suppose I have a User entity like this:

    class User {
        private String login;
        transient private String hashedPassword;
    }
    

    I don't want to ever transfer hashedPassword to clients, so I make it transient.

    This class is mapped by Hibernate, with both fields mapped in hbm.xml.

    Is this implementation safe and correct? Will Hibernate correctly store hashedPassword in database, load it into objects from database, keep it in replicated 2nd level cache and local session cache etc?

    In order words, does Hibernate or 2nd level cache respect transient in any way or completely ignore it?

    EDIT: I already got two answers that didn't seem to include one specific aspect of the equation. I am not using annotations at all, only XML mappings in hbm.xml. And this Java-transient field is OR-mapped in hbm.xml.

  • Konrad Garus
    Konrad Garus over 12 years
    Thank you, but I specifically mentioned that the field is mapped in hbm.xml. I'm not suing annotations at all.
  • Konrad Garus
    Konrad Garus over 12 years
    Thank you, but I specifically mentioned that the field is mapped in hbm.xml. I'm not suing annotations at all.
  • wrschneider
    wrschneider over 12 years
    Does Hibernate actually map the property in that case? I was under the assumption that annotations and hbm.xml behaved the same, but perhaps that's not the case. Since transient will ensure that the property is not serialized, is your question entirely about Hibernate behavior?
  • jayunit100
    jayunit100 over 12 years
    Yes thats true- the POJO annotation stuff is irrelevant. I added a bullet to address your question. In any case - its simple, just leave the variable out of your map - and hibernate will look the other way. No saving or caching will be done, because hibernate's "map" of your object will not include the unmapped variable.
  • Konrad Garus
    Konrad Garus over 12 years
    Thanks jay, but my point is quite opposite. I am asking whether it is always safe, 2nd lv cache and whatnot, to have a transient POJO field mapped with hbm.xml.