Я постараюсь объяснить вам это на примере. Предположим, у вас есть реляционная таблица (STUDENT) с двумя столбцами и ID (int) и NAME (String). Теперь, как 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;
}
}
Предположим, в таблице уже были записи. Теперь, если кто-то попросит вас добавить еще один столбец «ВОЗРАСТ» (int)
ALTER TABLE STUDENT ADD AGE int NULL
Вам нужно будет установить значения по умолчанию как NULL, чтобы добавить еще один столбец в предварительно заполненную таблицу. Это заставляет вас добавить еще одно поле в класс. Теперь возникает вопрос, будете ли вы использовать примитивный тип данных или непримитивный тип данных-оболочку для объявления поля.
@Column(name = "AGE")
private int age;
или
@Column(name = "AGE")
private INTEGER age;
вам придется объявить поле как непримитивный тип данных оболочки, потому что контейнер будет пытаться сопоставить таблицу с сущностью. Следовательно, он не сможет отобразить значения NULL (по умолчанию), если вы не объявите поле как оболочку, и в конечном итоге выдаст исключение «Нулевое значение было присвоено свойству установщика примитивного типа».