Hibernate关联之 一对一连接表单向关联
来源:互联网 发布:淘宝店铺最迟多久发货 编辑:程序博客网 时间:2024/05/29 11:13
Hibernate一对一连接表单向关联
这种情况很少见,但Hibernate同样允许采用连接表关联1-1.有连接表的1-1同样只需要将N-1的many-to-one元素增加unique="true"属性即可。
一、模型介绍
一个人(Person)对应一个地址(Address)。
二、实体(省略getter、setter方法)
public class Person11tab {
private int personid;
private String name;
private int age;
private Address11tab address11tab;
public class Address11tab {
private int addressid;
private String addressdetail;
三、表模型
mysql> desc address_11tab;
+---------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+---------------+--------------+------+-----+---------+----------------+
| addressid | int(11) | NO | PRI | NULL | auto_increment |
| addressdetail | varchar(255) | YES | | NULL | |
+---------------+--------------+------+-----+---------+----------------+
mysql> desc join_11tab;
+--------------+---------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+--------------+---------+------+-----+---------+-------+
| personid | int(11) | NO | PRI | | |
| address11tab | int(11) | YES | UNI | NULL | |
+--------------+---------+------+-----+---------+-------+
mysql> desc person_11tab;
+----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+--------------+------+-----+---------+----------------+
| personid | int(11) | NO | PRI | NULL | auto_increment |
| name | varchar(255) | YES | | NULL | |
| age | int(11) | YES | | NULL | |
+----------+--------------+------+-----+---------+----------------+
四、生成的SQL脚本
/* Formatted on 2007/08/20 16:52 (QP5 v5.50) */
CREATE TABLE `join_11tab` (
`personid` int(11) NOT NULL,
`address11tab` int(11) default NULL,
PRIMARY KEY (`personid`),
UNIQUE KEY `address11tab` (`address11tab`),
KEY `FK6B44BE20C4CC3D33` (`address11tab`),
KEY `FK6B44BE209049BB1F` (`personid`),
CONSTRAINT `FK6B44BE209049BB1F` FOREIGN KEY (`personid`) REFERENCES `person_11tab` (`personid`),
CONSTRAINT `FK6B44BE20C4CC3D33` FOREIGN KEY (`address11tab`) REFERENCES `address_11tab` (`addressid`)
) ENGINE=InnoDB DEFAULT CHARSET=gbk;
/* Formatted on 2007/08/20 16:53 (QP5 v5.50) */
CREATE TABLE `address_11tab` (
`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/20 16:53 (QP5 v5.50) */
CREATE TABLE `person_11tab` (
`personid` int(11) NOT NULL auto_increment,
`name` varchar(255) default NULL,
`age` int(11) default NULL,
PRIMARY KEY (`personid`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=gbk;
五、映射方法:
OneToOneTabPerson.hbm.xml
<hibernate-mapping> <class name="com.bean.Person11tab" table="PERSON_11tab"> <id name="personid"> <generator class="identity"/> </id> <property name="name"/> <property name="age"/> <!--使用join元素显式确定链接表--> <join table="join_11tab"> <key column="personid"/> <!--映射1-1关联属性,其中unique=“true”属性确定为“1-1”--> <many-to-one name="address11tab" unique="true"/> </join> </class> </hibernate-mapping>
OneToOneTabAddress.hbm.xml
<hibernate-mapping> <class name="com.bean.Address11tab" table="ADDRESS_11tab"> <id name="addressid"> <generator class="identity"/> </id> <property name="addressdetail"/> </class></hibernate-mapping>
public class Test_11tab {public static void main(String[] args){ Person11tab p1=new Person11tab(); p1.setName("cy"); p1.setAge(30); Address11tab add1=new Address11tab(); add1.setAddressdetail("哈尔滨群力"); p1.setAddress11tab(add1); Session session= HibernateUtil.getCurrentSession(); Transaction tx=session.beginTransaction(); session.save(add1); session.save(p1); tx.commit(); HibernateUtil.closeSession(); } }
- Hibernate关联之 一对一连接表单向关联
- Hibernate 一对一连接表单向关联
- Hibernate 一对一连接表单向关联
- Hibernate 一对一连接表单向关联
- Hibernate 一对一连接表单向关联
- Hibernate关联之 多对一连接表单向关联
- Hibernate 一对多连接表单向关联
- Hibernate 一对多连接表单向关联
- Hibernate 一对多连接表单向关联
- Hibernate 一对多连接表单向关联
- Hibernate关联之 一对一连接表双向关联
- Hibernate关联之一对多连接表单向关联
- Hibernate 关联映射 之 一对一 关联
- Hibernate关联关系之一对一(主键关联)
- hibernate关联映射之一对一单向关联
- Hibernate关联之 一对一主键单向关联
- Hibernate关联之一对一主键双向关联
- Hibernate之一对一关联映射
- map、set、multiset、multimap的有序性
- android实现滑动开关
- linux中将mongo作为系统服务启动
- 用C++实现一元多项式的四则运算包括数据的文件导入与导出
- 【java】类中使用getter和setter的优势
- Hibernate关联之 一对一连接表单向关联
- Big Endian 和 Little Endian
- ExecutorService多线程扫描全盘路径
- android免费天气预报接口api
- 协同OA的一大核心五大特征你知道吗?
- linux命令which whereis locate 命令
- Hibernate查询方式及关联
- Spring 源码解读 推荐流程
- Hive 查询