hibernate关联关系 (多对多)
hibernate的多对多
hibernate可以直接映射多对多关联关系(看作两个一对多
多对多关系注意事项
一定要定义一个主控方
多对多删除
主控方直接删除
被控方先通过主控方解除多对多关系,再删除被控方
禁用级联删除
关联关系编辑,不需要直接操作桥接表,hibernate的主控方会自动维护
一对多的自关联
映射文件TreeNode.hbm.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
- <hibernate-mapping>
- <class name="com.MavenHibernate.four.entity.TreeNode" table="t_hibernate_sys_tree_node">
- <id name="nodeId" type="java.lang.Integer" column="tree_node_id">
- <generator class="increment" />
- </id>
- <property name="nodeName" type="java.lang.String"
- column="tree_node_name">
- </property>
- <property name="treeNodeType" type="java.lang.Integer"
- column="tree_node_type">
- </property>
- <property name="position" type="java.lang.Integer"
- column="position">
- </property>
- <property name="url" type="java.lang.String"
- column="url">
- </property>
- <many-to-one name="parent" class="com.MavenHidernate.four.entity.TreeNode" column="parent_node_id"/>
- <set name="children" cascade="save-update" inverse="true">
- <key column="parent_node_id"></key>
- <one-to-many class="com.MavenHidernate.four.entity.TreeNode"/>
- </set>
- </class>
- </hibernate-mapping>
映射文件TreeNode.hbm.xml对应的实体类TreeNode.java
- package com.MavenHidernate.four.entity;
- import java.util.HashSet;
- import java.util.Set;
- public class TreeNode {
- private Integer nodeId;
- private String nodeName;
- private Integer treeNodeType;
- private Integer position;
- private String url;
- private TreeNode parent;
- private Set<TreeNode> children = new HashSet<TreeNode>();
- private Integer initChildren = 0;
- public Integer getNodeId() {
- return nodeId;
- }
- public void setNodeId(Integer nodeId) {
- this.nodeId = nodeId;
- }
- public String getNodeName() {
- return nodeName;
- }
- public void setNodeName(String nodeName) {
- this.nodeName = nodeName;
- }
- public Integer getTreeNodeType() {
- return treeNodeType;
- }
- public void setTreeNodeType(Integer treeNodeType) {
- this.treeNodeType = treeNodeType;
- }
- public Integer getPosition() {
- return position;
- }
- public void setPosition(Integer position) {
- this.position = position;
- }
- public String getUrl() {
- return url;
- }
- public void setUrl(String url) {
- this.url = url;
- }
- public TreeNode getParent() {
- return parent;
- }
- public void setParent(TreeNode parent) {
- this.parent = parent;
- }
- public Set<TreeNode> getChildren() {
- return children;
- }
- public void setChildren(Set<TreeNode> children) {
- this.children = children;
- }
- public Integer getInitChildren() {
- return initChildren;
- }
- public void setInitChildren(Integer initChildren) {
- this.initChildren = initChildren;
- }
- // @Override
- // public String toString() {
- // return "TreeNode [nodeId=" + nodeId + ", nodeName=" + nodeName + ", treeNodeType=" + treeNodeType
- // + ", position=" + position + ", url=" + url + ", children=" + children + "]";
- // }
- @Override
- public String toString() {
- return "TreeNode [nodeId=" + nodeId + ", nodeName=" + nodeName + ", treeNodeType=" + treeNodeType
- + ", position=" + position + ", url=" + url + ", parent=" + parent + ", children=" + children
- + ", initChildren=" + initChildren + "]";
- }
- }
TreeNodeDao方法
- package com.MavenHibernate.four.dao;
- import org.hibernate.Hibernate;
- import org.hibernate.Session;
- import org.hibernate.Transaction;
- import com.MavenHibernate.two.util.SessionFactoryUtils;
- import com.MavenHibernate.four.entity.TreeNode;
- public class TreeNodeDao {
- public TreeNode load(TreeNode treeNode) {
- Session session = SessionFactoryUtils.openSession();
- Transaction transaction = session.beginTransaction();
- TreeNode treenode = session.load(TreeNode.class, treeNode.getNodeId());
- if(treenode != null && new Integer(1).equals(treeNode.getInitChildren())) {
- Hibernate.initialize(t.getChildren());
- Hibernate.initialize(t.getParent());
- }
- transaction.commit();
- session.close();
- return treenode;
- }
- }
junit测试TreeNodeDao
TreeNodeDaoTest
- package com.MavenHibernate.four.dao;
- import org.junit.Test;
- import com.MavenHibernate.four.entity.TreeNode;
- public class TreeNodeDaoTest {
- private TreeNodeDao treeNodeDao = new TreeNodeDao();
- @Test
- public void testLoad() {
- TreeNode treeNode = new TreeNode();
- treeNode.setNodeId(6);
- treeNode.setInitChildren(1);
- TreeNode t = this.treeNodeDao.load(treeNode);
- System.out.println(t);
- System.out.println(t.getParent());
- System.out.println(t.getChildren());
- }
- }
多对多关联关系
映射文件category.hbm.xml
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
- <hibernate-mapping>
- <class name="com.MavenHibernate.four.entity.Category" table="t_hibernate_category">
- <id name="categoryId" type="java.lang.Integer" column="category_id">
- <generator class="increment" />
- </id>
- <property name="categoryName" type="java.lang.String"
- column="category_name">
- </property>
- <set table="t_hibernate_book_category" name="books" cascade="save-update" inverse="true">
- <key column="cid"></key>
- <many-to-many column="bid" class="com.MavenHibernate.four.entity.Book"></many-to-many>
- </set>
- </class>
- </hibernate-mapping>
映射文件category.hbm.xml对应的实体类category
- package com.MavenHibernate.four.entity;
- import java.io.Serializable;
- import java.util.HashSet;
- import java.util.Set;
- public class Category implements Serializable{
- // category_id int primary key auto_increment,
- // category_name varchar(50) not null
- private Integer categoryId;
- private String categoryName;
- private Set<Book> books = new HashSet<Book>();
- public Integer getCategoryId() {
- return categoryId;
- }
- public void setCategoryId(Integer categoryId) {
- this.categoryId = categoryId;
- }
- public String getCategoryName() {
- return categoryName;
- }
- public void setCategoryName(String categoryName) {
- this.categoryName = categoryName;
- }
- public Set<Book> getBooks() {
- return books;
- }
- public void setBooks(Set<Book> books) {
- this.books = books;
- }
- @Override
- public String toString() {
- return "Category [categoryId=" + categoryId + ", categoryName=" + categoryName + "]";
- }
- }
映射文件book.hbm.xml
- set标签
- table:对应的是中间表,没有实体类的,意味着靠两张主表对应的映射文件联合管理数据
- name:当前映射文件对应的实体类对应的属性
- cascade:级联新增修改,说白了就是当前实体类对应的表删除能否影响到关联表的数据
- inberse:中间表的数据维护的权利交给对方
- key标签
- column:当前表t_hibernate_book_category的主键book_id在中间表的列段bid
- many-to-many:
- column:代表中间表对应的除去当前表t_hibernate_book的非主键的中间列段cid
- class:cid对应的类
- <?xml version="1.0" encoding="UTF-8"?>
- <!DOCTYPE hibernate-mapping PUBLIC
- "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
- "http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
- <hibernate-mapping>
- <class name="com.MavenHibernate.four.entity.Book" table="t_hibernate_book">
- <cache usage="read-only" region="com.zking.five.entity.Book"/>
- <id name="bookId" type="java.lang.Integer" column="book_id">
- <generator class="increment" />
- </id>
- <property name="bookName" type="java.lang.String"
- column="book_name">
- </property>
- <property name="price" type="java.lang.Float"
- column="price">
- </property>
- <!--
- set标签
- table:对应的是中间表,没有实体类的,意味着靠两张主表对应的映射文件联合管理数据
- name:当前映射文件对应的实体类对应的属性
- cascade:级联新增修改,说白了就是当前实体类对应的表删除能否影响到关联表的数据
- inberse:中间表的数据维护的权利交给对方
- key标签
- column:当前表t_hibernate_book_category的主键book_id在中间表的列段bid
- many-to-many:
- column:代表中间表对应的除去当前表t_hibernate_book的非主键的中间列段cid
- class:cid对应的类
- -->
- <set table="t_hibernate_book_category" name="categories" cascade="save-update" inverse="true">
- <!-- one -->
- <key column="bid"></key>
- <!-- many -->
- <many-to-many column="cid" class="com.MavenHibernate.four.entity.Category"></many-to-many>
- </set>
- </class>
- </hibernate-mapping>
映射文件book.hbm.xml对应的实体类book
- package com.MavenHibernate.four.entity;
- import java.io.Serializable;
- import java.util.HashSet;
- import java.util.Set;
- public class Book implements Serializable{
- // book_id int primary key auto_increment,
- // book_name varchar(50) not null,
- // price float not null
- private Integer bookId;
- private String bookName;
- private Float price;
- private Set<Category> categories = new HashSet<Category>();
- private Integer initCategories = 0;
- public Integer getInitCategories() {
- return initCategories;
- }
- public void setInitCategories(Integer initCategories) {
- this.initCategories = initCategories;
- }
- public Integer getBookId() {
- return bookId;
- }
- public void setBookId(Integer bookId) {
- this.bookId = bookId;
- }
- public String getBookName() {
- return bookName;
- }
- public void setBookName(String bookName) {
- this.bookName = bookName;
- }
- public Float getPrice() {
- return price;
- }
- public void setPrice(Float price) {
- this.price = price;
- }
- public Set<Category> getCategories() {
- return categories;
- }
- public void setCategories(Set<Category> categories) {
- this.categories = categories;
- }
- @Override
- public String toString() {
- return "Book [bookId=" + bookId + ", bookName=" + bookName + ", price=" + price + "]";
- }
- public Book(Integer bookId, String bookName) {
- super();
- this.bookId = bookId;
- this.bookName = bookName;
- }
- public Book() {
- super();
- }
- }
hibernate.cfg.xml中配置映射文件
BookDao
- package com.MavenHibernate.four.dao;
- import java.util.HashMap;
- import java.util.List;
- import java.util.Map;
- import org.hibernate.Hibernate;
- import org.hibernate.Session;
- import org.hibernate.Transaction;
- import org.hibernate.query.Query;
- import com.MavenHibernate.two.util.SessionFactoryUtils;
- import com.MavenHibernate.four.entity.Book;
- import com.MavenHbernate.four.entity.Category;
- import com.mysql.jdbc.StringUtils;
- public class BookDao{
- public Integer addBook(Book book) {
- Session session = SessionFactoryUtils.openSession();
- Transaction transaction = session.beginTransaction();
- Integer bid = (Integer) session.save(book);
- transaction.commit();
- session.close();
- return bid;
- }
- public Integer addCategory(Category category) {
- Session session = SessionFactoryUtils.openSession();
- Transaction transaction = session.beginTransaction();
- Integer cid = (Integer) session.save(category);
- transaction.commit();
- session.close();
- return cid;
- }
- public Category getCategory(Category category) {
- Session session = SessionFactoryUtils.openSession();
- Transaction transaction = session.beginTransaction();
- Category c = session.get(Category.class, category.getCategoryId());
- transaction.commit();
- session.close();
- return c;
- }
- public Book getBook(Book book) {
- Session session = SessionFactoryUtils.openSession();
- Transaction transaction = session.beginTransaction();
- Book b = session.get(Book.class, book.getBookId());
- if (b != null && new Integer(1).equals(book.getInitCategories())) {
- Hibernate.initialize(b.getCategories());
- }
- transaction.commit();
- session.close();
- return b;
- }
- public void delBook(Book book) {
- Session session = SessionFactoryUtils.openSession();
- Transaction transaction = session.beginTransaction();
- session.delete(book);
- transaction.commit();
- session.close();
- }
- public void delCategory(Category category) {
- Session session = SessionFactoryUtils.openSession();
- Transaction transaction = session.beginTransaction();
- Category c = session.get(Category.class, category.getCategoryId());
- if(c!=null) {
- for (Book b : c.getBooks()) {
- // 通过在被控方通过主控方来解除关联关系,最后被控方再做删除
- b.getCategories().remove(c);
- }
- }
- session.delete(c);
- transaction.commit();
- session.close();
- }
- }
junit测试BookDao
- BookDaoTest
- package com.MavenHibernate.four.dao;
- import org.junit.Test;
- import com.MavenHibernate.four.entity.Book;
- import com.MavenHbernate.four.entity.Category;
- public class BookDaoTest {
- private BookDao bookDao = new BookDao();
- @Test
- public void testGetBook() {
- Book book = new Book();
- book.setBookId(8);
- book.setInitCategories(1);
- Book b = this.bookDao.getBook(book );
- System.out.println(b.getBookName());
- System.out.println(b.getCategories());
- }
- /**
- * book.hbm.xml inverse=fasle
- * category.hbm.xml inverse=true
- * 数据添加正常
- * 书籍表、桥接表各新增一条数据
- */
- @Test
- public void test1() {
- Book book = new Book();
- book.setBookName("jt5555555");
- book.setPrice(10f);
- Category category = new Category();
- category.setCategoryId(5);
- // 直接将category对象加入到新建的book中是错误的,因为此时的category是临时态的,hibernate是不会管理的
- // book.getCategories().add(category);
- Category c = this.bookDao.getCategory(category);
- // c.getBooks().add(book);
- book.getCategories().add(c);
- this.bookDao.addBook(book);
- }
- /**
- * book.hbm.xml inverse=false
- * category.hbm.xml inverse=true
- * 只增加书籍表数据
- * 桥接表不加数据
- * 原因:双方都没有去维护关系
- */
- @Test
- public void test2() {
- Book book = new Book();
- book.setBookName("T226");
- book.setPrice(10);
- Category category = new Category();
- category.setCategoryId(5);
- Category c = this.bookDao.getCategory(category);
- book.getCategories().add(c);
- this.bookDao.addBook(book);
- // c.getBooks().add(book);
- }
- }
hibernate关联关系 (多对多)的更多相关文章
- hibernate关联关系(多对多)
数据库的多对多数据库中不能直接映射多对多 处理:创建一个桥接表(中间表),将一个多对多关系转换成两个一对多 注:数据库多表联接查询 永远就是二个表的联接查询 注2:交叉连接 注3:外连接:left(左 ...
- hibernate关联关系的crud2
hibernate关联关系的CRUD操作,解释都在注释里了,讲了fetchType.cascade. User类: package com.oracle.hibernate; import javax ...
- Hibernate中多对多的annotation的写法(中间表可以有多个字段)
2011-07-04 6:52 一般情况下,多对多的关联关系是需要中间表的: 情况一:如果中间表仅仅是做关联用的,它里面仅有2个外键做联合主键,则使用ManyToMany(不用写中间表的Model,只 ...
- Hibernate 关联关系(一对多)
Hibernate 关联关系(一对多) 1. 什么是关联(association) 1.1 关联指的是类之间的引用关系.如果类A与类B关联,那么被引用的类B将被定义为类A的属性.例如: class B ...
- hibernate之多对多关系
hibernate的多对多hibernate可以直接映射多对多关联关系(看作两个一对多) 下面我们拿三张表来做实例 t_book_hb t_book_category_hb(桥接表) t_catego ...
- Hibernate关联关系的映射
实体之间的关系 实体之间有三种关系 一对多:一个用户,生成多个订单,每一个订单只能属于一个用户 建表原则:在多的一方创建一个字段,作为外键,指向一的一方的主键 多对多:一个学生可以选择多门课程,一个课 ...
- hibernate关联关系笔记
Hibernate关联关系笔记 单向N:1 * 有连接表:在N方使用<join>/<many-to-one>.1方无需配置与之关联的持久化类. * 没有连接表:在N方使用& ...
- Hibernate关联关系映射
1. Hibernate关联关系映射 1.1. one to one <class name="Person"> <id name="id" ...
- hibernate中多对多关联
hibernate中多对多关联 “计应134(实验班) 凌豪” 在关系数据库中有一种常见的关系即多对多关系,例如课程和学生的关系,一个学生可以选择多门课程,同时一门课程也可以被多个学生选择, 因此课程 ...
随机推荐
- mybatis使用associaton进行分步查询
Employee类 public class Employee { private Integer id; private String lastName; private String email; ...
- mysql的简介和使用
mysql简介 数据的所有存储,检索,管理和处理实际上是由数据库软件--DBMS(数据库管理系统)完成的 mysql是一种DBMS,即它是一种数据库软件 mysql工具 mysql是一个客户机-服务器 ...
- Laravel框架中Echo的使用过程
今天的这篇文章中给大家分享关于laravel框架中echo的使用,文章的内容是一步一步来的,用了16步走完一个过程,过程很清晰,希望可以帮助到有需要的朋友吧.话不多说,直接看内容.官方文档推荐使用 P ...
- Redis Persistent Replication Sentinel Cluster的一些理解
Redis Persistent Replication Sentinel Cluster的一些理解 我喜欢把工作中接触到的各种数据库叫做存储系统,笼统地说:Redis.Mysql.Kafka.Ela ...
- 【Luogu5349】幂(分治FFT)
[Luogu5349]幂(分治FFT) 题面 洛谷 题解 把多项式每一项拆出来考虑,于是等价于要求的只有\(\sum_{i=0}^\infty i^kr^i\). 令\(f(r)=\sum_{i=0} ...
- Java 8——保存参数名称
一.详述 在很多情况下,程序需要保存方法参数名称,如Mybatis中的mapper和xml中sql的参数绑定.但是在java 8之前的编译器是不支持保存方法参数名至class文件中的. 所以很多框架都 ...
- WPF 精修篇 获取系统颜色和字体样式
原文:WPF 精修篇 获取系统颜色和字体样式 看效果 <Grid> <Rectangle Fill="{DynamicResource {x:Static SystemCo ...
- 针对接口编程能帮助达到面向对象开发和设计中"低耦合"的要求. 某公司...打印机...(笔试中遇到的题目)
针对接口编程能帮助达到面向对象开发和设计中"低耦合"的要求. 举个例子:某公司有一台特殊打印机,还可以使用一年,一年后可能换为另一种打印机,这两种打印机都特殊而贵. ...
- 数据库系列(五)之 mysql的伸缩性
这篇文章,主要讲述mysql的伸缩性.在国内mysql一直都是使用得最多的数据库,在国外也排名前三.mysql是一款开源的.性能较高的数据库. 伸缩性是指在软件设计中,软件(数据库.应用程序)通过特定 ...
- ObjC: Foundation Kit
转自:http://marshal.easymorse.com/tech/objc-foundation-kit Foundation Kit是什么? 你可以把它看作Java JDK中的java.la ...