繼承映射策略之----每個具體類一張表
昨天我們看了繼承關系中的實現,昨天是用一張表保存所有級別的類,今天我們來了解一下第二種實現方法,每一個類一個單獨的表的實現,在數據庫我們的例子表現如下:
create table Person (
id integer primary key not null,
firstName varchar(255),
lastName varchar(255),
);
create table Customer (
id integer primary key not null,
firstName varchar(255),
lastName varchar(255),
street varchar(255),
city varchar(255),
state varchar(255),
zip varchar(255),
);
create table Employee (
id integer primary key not null,
firstName varchar(255),
lastName varchar(255),
street varchar(255),
city varchar(255),
state varchar(255),
zip varchar(255),
employeeId integer,
);
此種方式和SINGLE_TABLE的最大的不同就是這些表里面沒有了辨別器這一列了,我們不再需要為每一個特定的類設定一個標志以識別它是哪個具體的類了。在這種方式的實現里,每一張表都保存了該類的所有的屬性,當然也包括它從父類中繼承過來的屬性。我們看看代碼吧:
@Entity
@Inheritance(strategy=InheritanceType
.TABLE_PER_CLASS)
public class Person {

}
@Entity
public class Customer extends Person {

}
@Entity
public class Employee extends Customer {

}
從以上代碼可以看出,唯一需要的元數據注釋只有InheritanceType,并且這個注釋僅僅是用在基類Person上面而已,在他的子類中,根本看不出來有什么不一樣,它們就像一個很普通的實體BEAN一樣。
優點:
相比于SINGLE_TABLE的映射策略來說,此策略的優點是你可以在每一個子類上定義一些屬性的約束,比方說某些屬性不能為null等等,這些都是可以定義的,但是你在SINGLE_TABLE里面卻是不能定義的,它還有一個優點就是,它對于處理那些遺留的數據庫來說更加的容易一些,因為它更靈活一些。
缺點:
此策略依然是不規范的,沒有做到物盡其用,因為它為每一個子類都重復定義了很多列,這勢必給數據庫的資源造成了浪費,當需要進行多態加載的時候,就會進行多次查詢,這樣也會降低數據庫的查詢效率,這樣比較起來就沒有SINGLE_TABLE 策略速度快,但是它在別的方面性能會好一些,在開發你的實體BEAN的時候,最好不要用這種策略,除非你不得不這樣做,否則還是用第三種策略來得更好一些,那第三種策略是怎樣實現的呢,我們下次再講。
盡管千里冰封
依然擁有晴空
你我共同品味JAVA的濃香.
posted on 2007-10-09 00:21
千里冰封 閱讀(941)
評論(0) 編輯 收藏 所屬分類:
JAVAEE