2.joined-subclass映射策略
特点:父表的数据由父表保存,子表的数据由父表和子表共同保存。子类和父类共有的
属性保存在父表当中,子类扩展的属性保存在子表当中。采取该策略不需要辨别列。要为子表提供一个列【主键】映射父表的主键
表:
create table g_product( --父表--
p_id integer primary key,
p_name varchar2(30),
p_price number(4,2)
)
create table g_book( --子表--
c_id integer primary key references g_product(p_id),--与父表关联--
c_author varchar2(40)
)
映射文件
<joined-subclass name="Book" table="g_book" >
<key column="c_id"></key><!-- 外键声明 -->
<property name="author" column="c_author"></property>
</joined-subclass>
1.O提供对象属性实体类Product.java 和 Book.java
package com.jsu.hb.pojo; public class Product { private Integer id; private String name; private Double price; public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Double getPrice() { return price; } public void setPrice(Double price) { this.price = price; } }
Book.java
package com.jsu.hb.pojo; public class Book extends Product { private String author; public String getAuthor() { return author; } public void setAuthor(String author) { this.author = author; } }
2.R建表
create table g_product( p_id integer primary key, p_name varchar2(30), p_price number(6,2) ) create table g_book( c_id integer primary key references g_product(p_id), c_author varchar2(40) )
3.提供映射文件joined.hbm.xml
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.jsu.hb.pojo"> <!-- name:所操作对象的全路径 table:该对象所对应的表名 --> <class name="Product" table="g_product"> <id name="id" column="p_id"> <generator class="increment"></generator> </id> <!-- 普通属性的配置,非主键属性的配置 --> <property name="name" column="p_name"></property> <property name="price" column="p_price"></property> <!-- 采用joined-subclass处理book子类 --> <joined-subclass name="Book" table="g_book"> <key column="c_id"></key> <property name="author" column="c_author"></property> </joined-subclass> </class> </hibernate-mapping>
4.在hibernate.cfg.xml文件中对映射文件进行注册
<!DOCTYPE hibernate-configuration PUBLIC "-//Hibernate/Hibernate Configuration DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> <hibernate-configuration> <session-factory> <!-- show_sql:是否显示hibernate执行的SQL语句,默认为false --> <property name="show_sql">true</property> <!-- show_sql:是否显示hibernate执行格式化输出的SQL语句,默认为false --> <property name="format_sql">true</property> <!-- 配置与数据库连接的参数 --> <property name="connection.driver_class">oracle.jdbc.OracleDriver</property> <property name="connection.url">jdbc:oracle:thin:@127.0.0.1:1521:oracle</property> <property name="connection.username">scott</property> <property name="connection.password">tiger</property> <!-- 2.自身属性相关的配置 dialect:方言 hibernate根据dialect的配置进行特定数据性能方面的调优 --> <property name="dialect">org.hibernate.dialect.Oracle9iDialect</property> <mapping resource="com/jsu/hb/pojo/joined.hbm.xml"></mapping> </session-factory> </hibernate-configuration>
5.提供工具类HibernateUtil.java
package com.jsu.hb.util; import org.hibernate.Session; import org.hibernate.SessionFactory; import org.hibernate.cfg.Configuration; public class HibernateUtil { private static SessionFactory sf; private static ThreadLocal<Session> tl= new ThreadLocal<Session>(); static{ try{ Configuration cfg = new Configuration(); cfg.configure(); sf=cfg.buildSessionFactory(); }catch(Exception e){ e.printStackTrace(); } } public static Session openSession(){ return sf.openSession(); } public static Session getCurrentSession(){ Session session = tl.get();//先从储存的线程中查找 if(session==null){ session=openSession(); tl.set(session); return session; } return session; } }
6.提供测试类TestJoined.java
package com.jsu.hb.test; import org.hibernate.Session; import org.hibernate.Transaction; import org.junit.Test; import com.jsu.hb.pojo.Book; import com.jsu.hb.pojo.Product; import com.jsu.hb.util.HibernateUtil; public class TestJoined { @Test public void save(){ Product p = new Product(); p.setName("小米"); p.setPrice(1999.0); Book b = new Book(); b.setName("围城"); b.setPrice(38.5); b.setAuthor("沈从文"); Session session = HibernateUtil.getCurrentSession(); Transaction tx = session.getTransaction(); tx.begin(); session.save(p);//保存产品 //session.save(b);//保存图书 tx.commit(); } }
发表评论
-
Hibernateday06 QBC(Query by Criteria)
2012-07-24 16:59 864QBC (Query by Criteria)由hiberna ... -
Hibernateday06 SQLQuery 和NameQuery
2012-07-24 16:58 1250SqlQuery:在hibernate中使用sql Q ... -
Hibernateday06 HQL(Hibernate Query Language)
2012-07-21 22:18 1208HQL(hibernate query language) ... -
Hibernateday06学习笔记
2012-07-21 21:58 977HQL(hibernate query language) ... -
Hibernateday05继承关系union-subclass映射策略
2012-07-21 21:43 1016union-subclass映射策略 特点:父表 ... -
Hibernateday05继承关系subclass映射策略
2012-07-21 00:00 7612.继承关系 O Product //产品 ... -
Hibernateday05由一个主键类,将对象当中的联合作为主键的属性描述成一个对象【主键类的复合主键】
2012-07-20 23:53 8792.由一个主键类,将对象当中的联合作为主键的属性描述成一个对象 ... -
Hibernateday05对象当中的几个属性组合作为表的主键【实体类属性的复合主键】
2012-07-20 23:47 869复合主键 注意:1.对象必须实现序列化接口 1. ... -
Hibernateday05主键生成器(hilo)
2012-07-20 23:36 960主键生成器 generator class="xxx ... -
Hibernateday05学习笔记
2012-07-20 23:24 8091.一对多自身相关 员工找经理 关系属性 Emp ... -
Hibernateday04多对多关系
2012-07-19 23:19 715多对多 O Student C ... -
Hibernateday04一对多的自身相关(双向关系)
2012-07-19 01:04 735自身相关的双向关系 class Emp{ Inte ... -
Hibernateday04一对多的自身相关(从经理找员工)
2012-07-19 00:21 728从经理找员工{1:*} class Emp{ Integ ... -
Hibernateday04一对多的自身相关(从员工找经理)
2012-07-18 23:45 789对多的自身相关 以Emp表为例:一个雇员会有多个下属, ... -
Hibernateday04学习笔记
2012-07-18 23:19 661一对多 O Dept ... -
Hibernateday03一对多双向操作
2012-07-17 23:44 6711.建表 create table g_dept( ... -
Hibernateday03一对多单向操作
2012-07-17 22:37 762一对多 1:* Employee ... -
Hibernateday03学习笔记
2012-07-17 22:25 5991.Hibernate关联关系 一对一的关联关系 1 ... -
Hibernateday02表的唯一外键
2012-07-24 16:57 861一对一:唯一外键:为外键加上唯一约束 公司 Com ... -
Hibernateday02表的共享主键
2012-07-16 21:55 797关联关系 1:1 人 Person ...
相关推荐
本文将详细探讨Hibernate中处理继承关系的三种映射策略:subclass、joined-subclass以及union-subclass。 首先,让我们理解继承关系在面向对象编程中的重要性。继承允许我们创建一个类(子类)作为另一个类(父类)...
这种策略是Hibernate提供的四种继承映射策略之一,其他还包括“表-per-hierarchy”,“表-per-concrete-class”和“joined-subclass”。 首先,让我们理解什么是继承映射。在面向对象编程中,类可以有继承关系,...
在“extendMapping”项目中,可以看到`<joined-subclassname>`元素的使用,它允许每个子类拥有自己的表,并通过外键关联到基类表,形成所谓的“join table per subclass”策略。这种方式不仅能够避免单个表过于臃肿...
但Hibernate不支持在同一阶级元素下混合使用<subclass>、<joined-subclass>和<union-subclass>。 10.1.5. 每个具体类一张表(Table per concrete class) 每个具体类(非抽象类)都有自己的表,不包括抽象类。这种...
在Java世界中,ORM(对象关系映射)框架如Hibernate为开发者提供了便利,将数据库操作转化为面向对象的方式,使得数据库管理更加直观。本主题聚焦于“用Hibernate映射继承关系”,我们将深入探讨Hibernate如何处理...
Ansible-netbox-joined-inventory.zip,netbox_joined_inventory是一个python脚本,它从netbox真实源收集数据,并将其存储为ansible inventory、group_vars和host_vars files.netbox_joined_inventory(用于网络设备...
Hibernate提供了三种继承映射策略: 1. **单表继承(Single Table Inheritance)**:所有子类的实例数据都存储在同一个数据库表中,通过一个特定的字段(通常是`discriminator`字段)来区分不同子类的对象。 2. **...
在上一节的学习中,我们主要探讨了Hibernate的基础概念及其核心功能,包括如何配置Hibernate环境、基本的CRUD操作以及简单的对象关系映射(ORM)。其中特别强调了Hibernate如何帮助开发者简化数据库操作的过程,使...
- Hibernate提供了四种继承映射策略:`SINGLE_TABLE`、`JOINED`、`TABLE_PER_CLASS` 和 `MAPPED_SUPERCLASS`。每种策略都有其适用场景。 - `JOINED`策略适用于那些子类数据较少或者子类数量较多的情况,因为它能...
Hibernate继承映射是将Java中的继承关系映射到数据库的关系模型中。在Java中,一个基类可以有多个子类,而在数据库中,这些子类可以共享一张表或者各自拥有独立的表,这取决于我们选择的继承策略。Hibernate提供了四...
Hibernate支持四种继承映射策略:单表继承(Single Table Inheritance)、联合继承( Joined Subclass)、表 per 类继承(Table per Class Inheritance)和子类表(Concrete Table Inheritance)。在实际应用中,最...
在Java世界中,ORM(对象关系映射)框架如Hibernate极大地简化了数据库操作。本教程主要探讨的是Hibernate中的“继承映射”特性,这是一项关键功能,它允许我们将复杂的类继承结构映射到数据库表中。通过继承映射,...
Hibernate 是一款强大的Java对象关系映射(ORM)框架,它允许开发者将数据库操作转化为对Java对象的操作,简化了数据库编程。在 Hibernate 中,数据关联映射是实现对象与数据库表之间关系转换的关键技术。 1. **一...
在Java世界中,Hibernate是一个非常流行的ORM(对象关系映射)框架,它允许开发者用面向对象的方式处理数据库操作。在大型项目中,由于业务需求复杂,我们常常会使用到类的继承来组织代码结构,而Hibernate提供了对...
NX二次开发UF_CURVE_edit_joined_feature 函数介绍,Ufun提供了一系列丰富的 API 函数,可以帮助用户实现自动化、定制化和扩展 NX 软件的功能。无论您是从事机械设计、制造、模具设计、逆向工程、CAE 分析等领域的...
NX二次开发UF_CURVE_ask_joined_parms 函数介绍,Ufun提供了一系列丰富的 API 函数,可以帮助用户实现自动化、定制化和扩展 NX 软件的功能。无论您是从事机械设计、制造、模具设计、逆向工程、CAE 分析等领域的专业...
NX二次开发UF_CURVE_create_joined_curve 函数介绍,Ufun提供了一系列丰富的 API 函数,可以帮助用户实现自动化、定制化和扩展 NX 软件的功能。无论您是从事机械设计、制造、模具设计、逆向工程、CAE 分析等领域的...