例を参考にして、理解してもらいます。2つの列とID(int)およびNAME(String)を持つリレーショナルテーブル(STUDENT)があるとします。ORMとして、次のようなエンティティクラスを作成します。
package com.kashyap.default;
import java.io.Serializable;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Table;
/**
* @author vaibhav.kashyap
*
*/
@Entity
@Table(name = "STUDENT")
public class Student implements Serializable {
/**
*
*/
private static final long serialVersionUID = -1354919370115428781L;
@Id
@Column(name = "ID")
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int id;
@Column(name = "NAME")
private String name;
public Student(){
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
テーブルにすでにエントリがあると仮定しましょう。誰かがあなたに「AGE」の別の列を追加するように頼んだら(int)
ALTER TABLE STUDENT ADD AGE int NULL
事前入力されたテーブルに別の列を追加するには、デフォルト値をNULLに設定する必要があります。これにより、クラスに別のフィールドを追加できます。ここで、フィールドの宣言にプリミティブデータ型を使用するのか、プリミティブ以外のラッパーデータ型を使用するのかという疑問が生じます。
@Column(name = "AGE")
private int age;
または
@Column(name = "AGE")
private INTEGER age;
コンテナーはテーブルをエンティティーにマップしようとするため、フィールドをプリミティブ以外のラッパーデータ型として宣言する必要があります。したがって、フィールドをラッパーとして宣言せず、最終的に「Null値がプリミティブ型セッターのプロパティに割り当てられました」例外をスローすると、NULL値をマッピングできません(デフォルト)。