将一个对象(组件)作为属性,但是不想建立这个表

本文介绍Hibernate框架中如何使用组件映射来处理对象属性为另一个对象的情况,并通过具体示例展示了如何配置映射文件以实现这一功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

如果对象的某个属性为一个对象,而且不想单独对该对象建立一个表,这时Hibernate是这样处理的:

public class Name {


private String firstName;
private String SecondName;
public String getFirstName() {
return firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getSecondName() {
return SecondName;
}
public void setSecondName(String secondName) {
SecondName = secondName;
}


}



public class Employee {

private Integer id;
private Name name;
private Integer age;

public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public Name getName() {
return name;
}
public void setName(Name name) {
this.name = name;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
}



注意映射文件:

<?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="cn.itcast.hibernate.domain">

<class name="Employee" table="employee">
<id name="id" unsaved-value="-1">
<generator class="native" />
</id>
<property name="age" />
<component name="name">
<property name="firstName" column="first_name"/>
<property name="SecondName" column="second_name"/>
</component>
</class>
</hibernate-mapping>



测试代码:
import org.hibernate.Session;
import org.hibernate.Transaction;

import cn.itcast.hibernate.HibernateUtil;
import cn.itcast.hibernate.domain.Employee;
import cn.itcast.hibernate.domain.Name;

public class ComponentTest {

public static void main(String[] args) {
Session session = HibernateUtil.getSession();
Transaction tx = session.beginTransaction();

Name name = new Name();
name.setFirstName("firstname");
name.setSecondName("secondname");

Employee employee = new Employee();
employee.setAge(30);
employee.setName(name);

session.save(employee);

tx.commit();
session.close();
}

}



关键是映射文件中采用的标签component.

最终在数据库中生成的表的结构:

id int
age int
firstname varchar
secondname varchar

即所有字段都出现在同一个表中
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值