Hibernate 一对一主键单向关联
来源:互联网 发布:烂命鸳鸯知乎 编辑:程序博客网 时间:2024/05/21 21:34
Hibernate 一对一主键单向关联
1-1的关联可以基于主键关联,但基于主键关联的持久化类不能拥有自己的主键生成策略,它的主键由关联类负责生成。另外,另外,增加one-to-one元素来关联属性,必须为one-to-one元素增加constrained="true"属性,表明该类主键由关联类生成。
一、模型介绍
一个人(Person)对应一个地址(Address)。
二、实体(省略getter、setter方法)
public class Person11pk {
private int personid;
private String name;
private int age;
private Address11pk address11pk;
public class Address11pk {
private int addressid;
private String addressdetail;
三、表模型
mysql> desc address_11pk;
+---------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+---------------+--------------+------+-----+---------+----------------+
| addressid | int(11) | NO | PRI | NULL | auto_increment |
| addressdetail | varchar(255) | YES | | NULL | |
+---------------+--------------+------+-----+---------+----------------+
mysql> desc person_11pk;
+----------+--------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+----------+--------------+------+-----+---------+-------+
| personid | int(11) | NO | PRI | | |
| name | varchar(255) | YES | | NULL | |
| age | int(11) | YES | | NULL | |
+----------+--------------+------+-----+---------+-------+
四、生成的SQL脚本
/* Formatted on 2007/08/22 14:40 (QP5 v5.50) */
CREATE TABLE `address_11pk` (
`addressid` int(11) NOT NULL auto_increment,
`addressdetail` varchar(255) default NULL,
PRIMARY KEY (`addressid`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=gbk;
/* Formatted on 2007/08/22 14:41 (QP5 v5.50) */
CREATE TABLE `person_11pk` (
`presonid` int(11) NOT NULL,
`name` varchar(255) default NULL,
`age` int(11) default NULL,
PRIMARY KEY (`presonid`),
KEY `FK68A882C591BB393E` (`presonid`),
CONSTRAINT `FK68A882C591BB393E` FOREIGN KEY (`presonid`) REFERENCES `address_11pk` (`addressid`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
五、映射方法:在Person中配置id生成策略为:
<id name="personid">
<!--基于主键关联时,主键生成策略是foreign,表明根据关联类生成主键-->
<generator class="foreign">
<!--关联持久化类的属性名-->
<param name="property">address11pk</param>
</generator>
</id>
......
<!--用于映射1-1关联-->
<one-to-one name="address11pk" constrained="true"/>
<hibernate-mapping>
<class name="com.lavasoft.dx._1_1_pk.Person11pk" table="PERSON_11pk">
<id name="personid" column="presonid">
<!--基于主键关联时,主键生成策略是foreign,表明根据关联类生成主键-->
<generator class="foreign">
<!--关联持久化类的属性名-->
<param name="property">address11pk</param>
</generator>
</id>
<property name="name"/>
<property name="age"/>
<!--用于映射1-1关联-->
<one-to-one name="address11pk" constrained="true"/>
</class>
</hibernate-mapping>
<hibernate-mapping>
<class name="com.lavasoft.dx._1_1_pk.Address11pk" table="ADDRESS_11pk">
<id name="addressid">
<generator class="identity"/>
</id>
<property name="addressdetail"/>
</class>
</hibernate-mapping>
六、测试方法
public class Test_11pk {
public static void main(String[] args){
Person11pk p1=new Person11pk();
p1.setAge(21);
p1.setName("p1");
Address11pk add1=new Address11pk();
add1.setAddressdetail("郑州市经三路");
p1.setAddress11pk(add1);
Session session= HibernateUtil.getCurrentSession();
Transaction tx=session.beginTransaction();
session.save(add1);
session.save(p1);
tx.commit();
HibernateUtil.closeSession();
}
}
七、测试结果
1) :正常保存. 推荐这么干!
session.save(add1);
session.save(p1);
Hibernate: insert into ADDRESS_11fk (addressdetail) values (?)
Hibernate: insert into PERSON_11fk (name, age, addressId) values (?, ?, ?)
2) :正常保存.
session.save(p1);
session.save(add1);
Hibernate: insert into PERSON_11fk (name, age, addressId) values (?, ?, ?)
Hibernate: insert into ADDRESS_11fk (addressdetail) values (?)
Hibernate: update PERSON_11fk set name=?, age=?, addressId=? where personid=?
3) :正常保存.
// session.save(p1);
session.save(add1);
Hibernate: insert into ADDRESS_11fk (addressdetail) values (?)
4) : 发生异常,不能保存.
session.save(p1);
// session.save(add1);
Hibernate: insert into PERSON_11fk (name, age, addressId) values (?, ?, ?)
Exception in thread "main" org.hibernate.TransientObjectException: com.lavasoft.dx._1_1_fk.Address11fk
0 0
- Hibernate 一对一主键单向关联
- Hibernate 一对一主键单向关联
- Hibernate 一对一主键单向关联
- Hibernate:一对一单向主键关联
- Hibernate 一对一主键单向关联
- Hibernate关联之 一对一主键单向关联
- Hibernate XML一对一主键关联 单向+双向
- Hibernate 一对一主键单向、双向关联
- hibernate一对一单向主键关联_Annotation
- hibernate一对一单向主键关联_XML
- hibernate一对一主键关联_单向
- Hibernate映射(一)------单向一对一主键关联
- Hibernate一对一主键关联映射(单向)
- hibernate一对一主键关联单向(一)
- hibernate一对一主键关联单向(二)
- Hibernate关联关系之单向主键一对一
- Hibernate单向“一对一”关联
- Hibernate单向一对一关联
- valgrind的使用
- 浅谈多线程之锁的机制
- 机器学习-数据归一化方法
- 修改hdfs上目录的权限
- 1102: 整数幂(C语言输出左对齐格式)
- Hibernate 一对一主键单向关联
- 关于 safari浏览器 不支持new Date 显示NaN的问题记录
- 数组(二):ArrayList的实现和Arrays类的使用
- LintCode 主元素
- yolo v2 笔记
- 排序算法
- tcp、http 学习小结
- PC机安装ArchLinux详细步骤
- window系统,wamp下nginx配置TP使用