hibernate多对多映射
程序员文章站
2022-03-06 22:25:35
...
一、创建实体类
package com.wr.hibernate.entity; import java.util.HashSet; import java.util.Set; public class Person { private int id; private String name; private Set<Role> roles = new HashSet<Role>(); public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Set<Role> getRoles() { return roles; } public void setRoles(Set<Role> roles) { this.roles = roles; } }
package com.wr.hibernate.entity; import java.util.HashSet; import java.util.Set; public class Role { private int id; private String name; private Set<Person> persons = new HashSet<Person>(); public Set<Person> getPersons() { return persons; } public void setPersons(Set<Person> persons) { this.persons = persons; } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } }
二、创建POJO映射
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.wr.hibernate.entity"> <class name="Person" table="person"> <id name="id" type="java.lang.Integer"> <column name="person_id" /> <!-- 指定主键的生成方式, native: 使用数据库本地方式 --> <generator class="native" /> </id> <property name="name" type="java.lang.String"> <column name="person_name" /> </property> <!-- 指定中间表person_role --> <set name="roles" table="person_role"> <key column="person_id"></key> <many-to-many class="Role" column="role_id"></many-to-many> </set> </class> </hibernate-mapping>
<?xml version="1.0"?> <!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"> <hibernate-mapping package="com.wr.hibernate.entity"> <class name="Role" table="role"> <id name="id" type="java.lang.Integer"> <column name="role_id" /> <!-- 指定主键的生成方式, native: 使用数据库本地方式 --> <generator class="native" /> </id> <property name="name" type="java.lang.String"> <column name="role_name" /> </property> <!-- 指定中间表person_role --> <set name="persons" table="person_role" inverse="true"> <key column="role_id"></key> <many-to-many class="Person" column="person_id"></many-to-many> </set> </class> </hibernate-mapping>
上一篇: hibernate一对一外键关联
下一篇: 高并发系统开发碎碎念 服务器并发
推荐阅读
-
hibernate一对多&多对多关系的操作(四)
-
Mybatis动态sql、if与where的使用、sql片段、foreach遍历、Mybatis的关联查询一对一、一对多、多对多、Mybatis的延时加载
-
mysql-怎么回事,Hibernate这样也能成功,但这么多警告,怎么回事?
-
mybatis 一对一、一对多和多对多查询实例代码
-
mybatis 一对一、一对多和多对多查询实例代码
-
PageHelper插件实现一对多查询时的分页问题
-
EJB3.0开发之多对多和一对一
-
Django的数据模型访问多对多键值的方法
-
关于多对多关系表无法更新与插入的问题
-
详解sql中的参照完整性(一对一,一对多,多对多)