版权声明: 原创作品,如需转载,请与作者联系。否则将追究法律责任。
Hibernate 一对一外键单向关联
事实上,单向1-1 与N-1 的实质是相同的,1-1 是N-1 的特例,单向1-1 与N-1 的映射配置也非常相似。只需要将原来的many-to-one 元素增加unique="true" 属性,用于表示N 的一端也必须是唯一的,在N 的一端增加了唯一的约束,即成为单向1-1 。基于外键的单向1-1 的配置将与无连接表N-1 关联的many-to-one 增加unique="true" 属性即可。
一、模型介绍
一个人(Person )对应一个地址(Address )。
二、实体(省略getter 、setter 方法)
三、表模型
mysql> desc address_11fk;
+---------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+---------------+--------------+------+-----+---------+----------------+
| addressid | int(11) | NO | PRI | NULL | auto_increment |
| addressdetail | varchar(255) | YES | | NULL | |
+---------------+--------------+------+-----+---------+----------------+
mysql> desc person_11fk;
+-----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-----------+--------------+------+-----+---------+----------------+
| personid | int(11) | NO | PRI | NULL | auto_increment |
| name | varchar(255) | YES | | NULL | |
| age | int(11) | YES | | NULL | |
| addressId | int(11) | YES | UNI | NULL | |
+-----------+--------------+------+-----+---------+----------------+
四、生成的SQL 脚本
CREATE TABLE `address_11fk` (
`addressid` int(11) NOT NULL auto_increment,
`addressdetail` varchar(255) default NULL,
PRIMARY KEY (`addressid`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=gbk;
CREATE TABLE `person_11fk` (
`personid` int(11) NOT NULL auto_increment,
`name` varchar(255) default NULL,
`age` int(11) default NULL,
`addressId` int(11) default NULL,
PRIMARY KEY (`personid`),
KEY `FK68A8818F3F45AA77` (`addressId`),
CONSTRAINT `FK68A8818F3F45AA77` FOREIGN KEY (`addressId`) REFERENCES `address_11fk` (`addressid`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=gbk;
五、映射方法:
在Person 中添加Address 属性,映射配置为:
六、测试方法
七、测试结果
