Transient properties
We take a closer look at Figure 937, “Mapping hibintro.v1.model.User
instances
to a database. ”
assuming that Instances of
hibintro.v1.model.User
need an additional
GUI related property
selected
❶:
package hibintro.v2;
import javax.persistence.Entity;
import javax.persistence.Id;
/**
* A simple class intended to be mapped to a database server
*/
@Entity
public class User {
String uid;
/**
* @return The user's unique login name e.g. "goik"
*/
@Id
public String getUid() {
return uid;
}
/**
* @param uid See {@link #getUid()}.
*/
public void setUid(String uid) {
this.uid = uid;
}
String cname;
/**
* @return The user's common name e.g. "Martin Goik"
*/
public String getCname() {
return cname;
}
/**
* @param cname See {@link #getCname()}.
*/
public void setCname(String cname) {
this.cname = cname;
}
boolean selected = false; ❶
public boolean isSelected() {
return selected;
}
public void setSelected(boolean selected) {
this.selected = selected;
}
protected User() {}
/**
* @param uid See {@link #getUid()}.
* @param cname See {@link #getCname()}.
*/
public User(String uid, String cname) {
this.uid = uid;
this.cname = cname;
}
}
Hibernates produces the following DDL
statements containing an attribute selected
❶:
CREATE TABLE User (
uid VARCHAR(255) NOT NULL PRIMARY KEY,
cname VARCHAR(255),
selected ❶ BIT NOT NULL,
)
If we just annotate a Java class with an
javax.persistence.Entity
Annotation all
properties of the class in question will be mapped. A JPA framework of course cannot distinguish between
transient and persistent properties. If we want a property to be
transient we have to add a javax.persistence.Transient
annotation:
Java |
|
SQL |
|
The javax.persistence.Transient
annotation inhibits the mapping of our property
selected
.
Caution
When loading a hibintro.v3.User
instance from a database all transient property values are of course
entirely determined by the default constructor.