hibernate之关于使用连接表实现多对一关联映射
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了hibernate之关于使用连接表实现多对一关联映射,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2450字,纯文字阅读大概需要4分钟。
内容图文
【Hibernate】之关于使用连接表实现多对一关联映射
在我们项目使用中采用中间表最多的一般就是多对一,或者是多对多,当然一对一使用中间表也是可以的,但是这种几率通常少之又少!所以这里重点介绍多对一和一对多的采用中间表进行关联映射!
依然采用Group和Person来描述这个逻辑!
Annotations配置
@Entity @Table(name="t_group") publicclass Group { private Integer id; private String name; @Id @GeneratedValue public Integer getId() { returnid; } publicvoid setId(Integer id) { this.id = id; } @Column(name="g_name") public String getName() { returnname; } publicvoid setName(String name) { this.name = name; } }
@Entity @Table(name="p_person") publicclass Person { private Integer id; private String name; private Integer age; private Group group; @ManyToOne
//下面是配置中间表的核心 @JoinTable(name="g_p",joinColumns={@JoinColumn(name="p_id")}, inverseJoinColumns={@JoinColumn(name="g_id")}) public Group getGroup() { returngroup; } publicvoid setGroup(Group group) { this.group = group; } @Id @GeneratedValue public Integer getId() { returnid; } publicvoid setId(Integer id) { this.id = id; } @Column(name="p_name") public String getName() { returnname; } publicvoid setName(String name) { this.name = name; } @Column(name="p_age") public Integer getAge() { returnage; } publicvoid setAge(Integer age) { this.age = age; } }
XML配置
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/HibernateMapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="csg.hibernate.entity"> <class name="Person" table="t_person"> <id name="id"> <column name="id"/> <generator class="native" /> </id> <property name="name" /> <property name="age" /> <join table="t_p" optional="true"> <key column="p_id"></key> <many-to-one name="group" column="g_id" class="Group" unique="true"/> </join> </class> </hibernate-mapping>
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/HibernateMapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="csg.hibernate.entity"> <class name="Group" table="t_group"> <id name="id"> <column name="id"/> <generator class="native" /> </id> <property name="name" /> </class> </hibernate-mapping>
写这篇文章,我特意查询了一下网上的文章,发现大家都是采用XML配置的,所以我这里也写了Annotations配置,因为JPA中的Annotations使用起来远比XML要方便!OK?
XML配置
原文:http://blog.csdn.net/u010506940/article/details/40543275
内容总结
以上是互联网集市为您收集整理的hibernate之关于使用连接表实现多对一关联映射全部内容,希望文章能够帮你解决hibernate之关于使用连接表实现多对一关联映射所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。