我有以下休眠映射,必须使用每个具体类层次结构的表进行映射:
<hibernate-mapping package='dao'>
<meta attribute='class-description'></meta>
<class name='PropertyDAO'>
<id name='id' column='id_property'>
<generator class='assigned'/>
</id>
<property name='address' column='address' type='string'/>
<union-subclass name='HouseDAO' table='house'>
<property name='noOfRooms' column='noOfRooms'/>
<property name='totalArea' column='totalArea'/>
<property name='price' column='price'/>
</union-subclass>
<union-subclass name='LandDAO' table='land'>
<property name='area' column='area'/>
<property name='unitPrice' column='unitPrice'/>
</union-subclass>
</class>
</hibernate-mapping>
这意味着在数据库中我只有 2 个表:
- 房子(id_property(PK),地址,noOfRooms,totalArea,价格)
- 土地(id_property(PK),地址,面积,单价)
据我了解,在这种情况下,需要在调用 .save() 之前显式生成 id,所以我的问题是:如何创建自动生成 id 的策略,以便来自具体类的 id加入时形成一个连续的域。