Hibernate 一对一主键双向关联
来源:互联网 发布:300533冰川网络 编辑:程序博客网 时间:2024/05/14 23:42
Hibernate 一对一主键双向关联
一对一主键映射在一对一映射中还算是最为常用的。
一、模型
一个人Person 对应一个地址Address。
二、数据模型和对象模型图
导出建表SQL如下:
/*==============================================================*/
/* DBMS name: MySQL 5.0 */
/* Created on: 2008-12-8 23:05:32 */
/*==============================================================*/
drop table if exists address;
drop table if exists person;
/*==============================================================*/
/* Table: address */
/*==============================================================*/
create table address
(
id bigintnot null comment'ID',
detail varchar(120)not null comment'详细地址',
primary key (id)
)
type = InnoDB;
alter table address comment'地址';
/*==============================================================*/
/* Table: person */
/*==============================================================*/
create table person
(
id bigintnot null auto_increment comment'ID',
name varchar(24) not null comment '姓名',
primary key (id)
)
type = InnoDB;
alter table person comment'人';
alter table addressadd constraint FK_Reference_2foreign key (id)
references person (id) on delete restricton update restrict;
/* DBMS name: MySQL 5.0 */
/* Created on: 2008-12-8 23:05:32 */
/*==============================================================*/
drop table if exists address;
drop table if exists person;
/*==============================================================*/
/* Table: address */
/*==============================================================*/
create table address
(
id bigintnot null comment'ID',
detail varchar(120)not null comment'详细地址',
primary key (id)
)
type = InnoDB;
alter table address comment'地址';
/*==============================================================*/
/* Table: person */
/*==============================================================*/
create table person
(
id bigintnot null auto_increment comment'ID',
name varchar(24) not null comment '姓名',
primary key (id)
)
type = InnoDB;
alter table person comment'人';
alter table addressadd constraint FK_Reference_2foreign key (id)
references person (id) on delete restricton update restrict;
三、对象模型代码
public class Personimplements java.io.Serializable {
private Long id;
private String name;
private Address address;
private Long id;
private String name;
private Address address;
public class Addressimplements java.io.Serializable {
private Long id;
private Person person;
private String detail;
private Long id;
private Person person;
private String detail;
四、映射代码
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="entity.Person" table="person">
<id name="id" type="java.lang.Long">
<columnname="id" />
<generatorclass="identity"/>
</id>
<propertyname="name"type="java.lang.String">
<columnname="name"length="24"not-null="true">
<comment>姓名</comment>
</column>
</property>
<!-- cascade="all":在保存person对象的时候,级联保存person对象关联的address对象 -->
<one-to-onename="address"cascade="all"/>
</class>
</hibernate-mapping>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="entity.Person" table="person">
<id name="id" type="java.lang.Long">
<columnname="id" />
<generatorclass="identity"/>
</id>
<propertyname="name"type="java.lang.String">
<columnname="name"length="24"not-null="true">
<comment>姓名</comment>
</column>
</property>
<!-- cascade="all":在保存person对象的时候,级联保存person对象关联的address对象 -->
<one-to-onename="address"cascade="all"/>
</class>
</hibernate-mapping>
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="entity.Address" table="address" catalog="mydb">
<id name="id" type="java.lang.Long">
<columnname="id" />
<!-- class="foreign": 一对一主键映射中,使用另外一个相关联的对象的标识符-->
<generatorclass="foreign">
<paramname="property">person</param>
</generator>
</id>
<propertyname="detail"type="java.lang.String">
<columnname="detail"length="120"not-null="true">
<comment>详细地址</comment>
</column>
</property>
<!-- 表示在address表存在一个外键约束,外键参考相关联的表person -->
<one-to-onename="person"constrained="true"/>
</class>
</hibernate-mapping>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="entity.Address" table="address" catalog="mydb">
<id name="id" type="java.lang.Long">
<columnname="id" />
<!-- class="foreign": 一对一主键映射中,使用另外一个相关联的对象的标识符-->
<generatorclass="foreign">
<paramname="property">person</param>
</generator>
</id>
<propertyname="detail"type="java.lang.String">
<columnname="detail"length="120"not-null="true">
<comment>详细地址</comment>
</column>
</property>
<!-- 表示在address表存在一个外键约束,外键参考相关联的表person -->
<one-to-onename="person"constrained="true"/>
</class>
</hibernate-mapping>
五、Hibernate配置
<?xml version='1.0' encoding='UTF-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<propertyname="connection.username">root</property>
<propertyname="connection.url">
jdbc:mysql://localhost:3306/mydb
</property>
<propertyname="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<propertyname="connection.password">xiaohui</property>
<propertyname="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<propertyname="show_sql">true</property>
<propertyname="format_sql">true</property>
<mapping resource="entity/Person.hbm.xml" />
<mapping resource="entity/Address.hbm.xml" />
</session-factory>
</hibernate-configuration>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<!-- Generated by MyEclipse Hibernate Tools. -->
<hibernate-configuration>
<session-factory>
<propertyname="connection.username">root</property>
<propertyname="connection.url">
jdbc:mysql://localhost:3306/mydb
</property>
<propertyname="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<propertyname="connection.password">xiaohui</property>
<propertyname="connection.driver_class">
com.mysql.jdbc.Driver
</property>
<propertyname="show_sql">true</property>
<propertyname="format_sql">true</property>
<mapping resource="entity/Person.hbm.xml" />
<mapping resource="entity/Address.hbm.xml" />
</session-factory>
</hibernate-configuration>
0 0
- Hibernate 一对一主键双向关联
- Hibernate 一对一主键双向关联
- Hibernate 一对一主键双向关联
- Hibernate一对一主键双向关联
- hibernate一对一主键双向关联
- hibernate一对一主键双向关联
- Hibernate:一对一双向主键关联
- Hibernate 一对一主键双向关联
- Hibernate 一对一主键双向关联
- Hibernate关联之一对一主键双向关联
- Hibernate XML一对一主键关联 单向+双向
- Hibernate 一对一主键单向、双向关联
- 一个Hibernate一对一主键双向关联实例
- hibernate一对一双向主键关联_Annotation
- hibernate一对一双向主键关联_XML
- hibernate一对一主键关联映射双向
- Hibernate一对一主键关联映射(双向)
- 13.Hibernate一对一外键&一对一主键双向关联
- Direct3D---纹理映射
- nodejs+bigpipe+angularjs技术实现
- hdu 2008 数值统计
- 金额验证,小数点和数字可以输入,其它不能操作
- 学会如何调试程序bug
- Hibernate 一对一主键双向关联
- 构造函数的调用时机/次数
- Ubuntu 12.04 IP 配置
- 协程和异步
- 2017年该到哪里买房?只需看这个指标!(GDP含税量、人均国税)
- 20170208大量Http请求close_wait的问题
- 国密SKF接口函数介绍之四:文件管理函数
- 关于Java协程和Kilim的一些概念
- SQL 语句优化