文档章节

Hibernate 级联属性

萧小蚁
 萧小蚁
发布于 2015/06/15 00:09
字数 1318
阅读 28
收藏 0

精选30+云产品,助力企业轻松上云!>>>

级联状态

cascade(级联)

用来指定两个对象之间的操作联动关系。当主控方执行操作时,关联对象(被动方)是否同步执行同一操作。

常用可选值

none:所有情况下均不进行级联操作。这是默认值。

save-update: 在执行保存和更新时进行级联操作。

delete:在执行删除时进行级联操作。

all : 所有情况下均进行级联操作。

级联只对增、删、改起作用。

inverse="true"和cascade="all"同时使用:

级联delete操作可以正常进行, insert和update会级联操作,但不维护关联关系。

注意:如果inverse="true"和cascade="all"同时使用,为了在做insert和update操作时同样能够

进行级联操作,需要在被控端同时维护一对多和多对一两个关系。

package model;

import java.util.Set;

/**
 * @author sally
 * 双向的一对多或多对一 自身关联
 */
public class Category {

	private int id;
	private String name;
	//如果把Category看成是多的一端
	private Category parent;
	//如果把Category看成是少的一端,则需要对多的一端进行对象集合的引用
	private Set<Category> clist;
	
	public Category(){
		
	}

	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 Category getParent() {
		return parent;
	}

	public void setParent(Category parent) {
		this.parent = parent;
	}

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC 
	"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
	<!-- name属性指定类名(全限定名) table指明表名,不指明table数据默认的表名和实体名一致 -->
    <class name="model.Category" table="cate_tab">
    	<!-- type指明当前字段的类型    name对应实体中的属性名 -->
        <id type="integer" name="id">
        	<!-- 提供ID自增的策略  native会根据数据库自行判断 -->
            <generator class="native"/>
        </id>
        <property name="name" type="string"></property>
        <set name="clist" inverse="false" cascade="all">
        	<key column="parent_id"></key>
        	<!-- 配置一对多的关联映射 -->
        	<one-to-many class="model.Category"/>
        </set>
        <many-to-one name="parent" column="parent_id"></many-to-one>
        
    </class>	
</hibernate-mapping>

<!DOCTYPE hibernate-configuration PUBLIC
	"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
	"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">

<hibernate-configuration>
	<session-factory>
		<!-- 配置连接数据库的参数 -->
		<!-- 配置数据库的方言 -->
		<property name="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</property>
		<!-- 数据库驱动 -->
		<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
		<property name="hibernate.connection.url">jdbc:mysql:///2o2mzishen</property>
		<property name="hibernate.connection.username">root</property>
		<property name="hibernate.connection.password">root</property>
		 <property name="hibernate.show_sql">true</property>
		 <!-- 其它属性配置 -->
		<!-- 指明C3P0的提供者 -->
		<property name="hibernate.connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
		<!-- 连接池参数的配置 -->
		<property name="hibernate.c3p0.min_size">5</property> 
	    <property name="hibernate.c3p0.max_size">30</property> 
	    <property name="hibernate.c3p0.timeout">1800</property> 
	    <property name="hibernate.c3p0.max_statements">50</property>
	    
	    <!-- 打印SQL语句到控制台 -->
		<property name="hibernate.show_sql">true</property>
		<property name="hibernate.format_sql">true</property>
		<property name="hibernate.hbm2ddl.auto">update</property> 
		<!-- 注册实体的对象关系映射文件 -->
		
		<mapping resource="model/Category.hbm.xml"/>
		
	</session-factory>
</hibernate-configuration>

package util;

import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;

public class HibernateUtils {

	private static SessionFactory factory;
	static{
		factory=new Configuration().configure().buildSessionFactory();
	}
	public static SessionFactory getFactory(){
		return factory;
	}
	
	public static Session getSession(){
		return factory.openSession();
	}
	
	public static void close(Session session){
		if(session!=null){
			session.close();
		}
		
	}
	
}

package test;


import java.util.HashSet;
import java.util.Set;

import model.Category;

import org.hibernate.Session;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import org.hibernate.tool.hbm2ddl.SchemaExport;
import org.junit.Test;

import util.HibernateUtils;

public class O2mTest {

	@Test
	public void createTable(){
		Configuration cfg=new Configuration().configure();
		SchemaExport se=new SchemaExport(cfg);
		se.create(true, true);
	}
	/**
	 * 先添加多的一端,再添加少的一端
	 */
	@Test
	public void save(){
		Session session=HibernateUtils.getSession();
		Transaction ts=session.beginTransaction();
		
		//添加一级分类
		Category c1=new Category();
		c1.setName("计算机");
		session.save(c1);
		
		//添加二级分类
		Category c2=new Category();
		c2.setName("软件开发");
		c2.setParent(c2);
		session.save(c2);
		
		//添加二级分类
		Category c3=new Category();
		c3.setName("硬件维修");
		c3.setParent(c3);
		session.save(c3);
		
		ts.commit();
		HibernateUtils.close(session);
	}
	/**
	 * 先添加少的一端,再添加多的一端
	 */
	@Test
	public void save1(){
		Session session=HibernateUtils.getSession();
		Transaction ts=session.beginTransaction();
		
		
		
		ts.commit();
		HibernateUtils.close(session);
	}
	/**
	 * Inverse = true,不指定cascade
    cascade的默认值为none, 当对一级分类进行保存操作时,二级分类什么都不做. 所以只保存了一级分类对象, 没有保存二级分类对象
	 */
	@Test
	public void save2(){
		Session session=HibernateUtils.getSession();
		Transaction ts=session.beginTransaction();
		
		//添加一级分类
				Category c1=new Category();
				c1.setName("手机");
				
				//添加二级分类
				Category c2=new Category();
				c2.setName("小米");
				//添加二级分类
				Category c3=new Category();
				c3.setName("华为");
				
				Set<Category> c=new HashSet<>();
				c.add(c2);
				c.add(c3);
				c1.setClist(c);
				
				session.save(c1);
					
		ts.commit();
		HibernateUtils.close(session);
	}
	/**
	 * Inverse = true,cascade=all
    一级分类与二级分类对象,包扩外键[经过测试,发现外键没有成保存,值为null]都成功保存。
    
	 */
	@Test
	public void save4(){
		Session session=HibernateUtils.getSession();
		Transaction ts=session.beginTransaction();
		
		//添加一级分类
				Category c1=new Category();
				c1.setName("手机");
				
				
				//添加二级分类
				Category c2=new Category();
				c2.setName("小米");
				//添加二级分类
				Category c3=new Category();
				c3.setName("华为");
				
				Set<Category> c=new HashSet<>();
				c.add(c2);
				c.add(c3);
				c1.setClist(c);
				
				session.save(c1);
					
		ts.commit();
		HibernateUtils.close(session);
	}
	
	/**
	 * Inverse = false,cascade=all
    一级分类与二级分类对象都能保存成功,包扩外键都成功保存。
    
	 */
	@Test
	public void save5(){
		Session session=HibernateUtils.getSession();
		Transaction ts=session.beginTransaction();
		
		//添加一级分类
				Category c1=new Category();
				c1.setName("手机");
				
				
				//添加二级分类
				Category c2=new Category();
				c2.setName("小米");
				//添加二级分类
				Category c3=new Category();
				c3.setName("华为");
				
				Set<Category> c=new HashSet<>();
				c.add(c2);
				c.add(c3);
				c1.setClist(c);
				
				session.save(c1);
					
		ts.commit();
		HibernateUtils.close(session);
	}
	
	/**
	 * Inverse = false,不指定cascade=all
  报错。因为少的一端为主控方,负责维护关系,所以在插入少的一端对象后,会尝试修改并不存在的多的一端对象。  
	 */
	@Test
	public void save6(){
		Session session=HibernateUtils.getSession();
		Transaction ts=session.beginTransaction();
		
		//添加一级分类
				Category c1=new Category();
				c1.setName("手机");
				
				
				//添加二级分类
				Category c2=new Category();
				c2.setName("小米");
				//添加二级分类
				Category c3=new Category();
				c3.setName("华为");
				
				Set<Category> c=new HashSet<>();
				c.add(c2);
				c.add(c3);
				c1.setClist(c);
				
				session.save(c1);
					
		ts.commit();
		HibernateUtils.close(session);
	}
	
	/**
	 * 
	 */
	@Test
	public void delete(){
		Session session=HibernateUtils.getSession();
		Transaction ts=session.beginTransaction();
		Category c=(Category)session.get(Category.class,7);
		session.delete(c);
		
		ts.commit();
		HibernateUtils.close(session);
	}
	
	
}


萧小蚁

萧小蚁

粉丝 101
博文 279
码字总数 192339
作品 0
海淀
程序员
私信 提问
加载中
请先登录后再评论。
3 OneToMany ManyToMany MappedBy Cascade

1 双向1-N关联 对于1-N关联,Hibernate推荐使用双向关联,而且不要让1的一方控制关联关系,而使用多的一方控制关联关系。 a. 一的一方 表示班级 @Entity@Table(name="team_1")public class T...

恋佳
2015/07/22
42
0
Hibernate4之一对一关联

每个用户注册信息就对应一个登录信息,双方是相互依存的,由于主键共享,如果有任意表的一条记录被删除或者新增,那么另一张表也会删除对应的记录或者新增一条记录。而且一对一不管是save还是...

一日一博
2015/11/25
13
0
Hibernate级联之一对多和inverse解析

hibernate的级联可以说是hibernate最重要的部分,只有深入了解了级联的特性与用法,才能运用自如。   这次讨论一对多的情况,所以就使用博客项目的用户表和博客表作为示例,来一起学习hib...

宇的季节
2017/11/28
0
0
hibernate 配置@ManyToOne 等关联关系注解中 cascade属性设置不起作用问题

@ManyToOne(fetch = FetchType.EAGER,cascade = CascadeType.ALL) 关联关系注解属性cascade,在使用hibernate时,只有 CascadeType.ALL,其它类型不起作用,如果只想级联保存,不级联删除,就...

凯丽甘
2015/09/24
406
0
Hibernate级联之一对多和inverse解析

hibernate的级联可以说是hibernate最重要的部分,只有深入了解了级联的特性与用法,才能运用自如。   这次讨论一对多的情况,所以就使用博客项目的用户表和博客表作为示例,来一起学习hib...

宇的季节
2017/11/28
0
0

没有更多内容

加载失败,请刷新页面

加载更多

PG库实现 t+1 同步

需求:业务场景中有很多需要查询t+1的数据,但又不想影响生产实时的业务,是否可以搭建一个延时的灾备库就可以解决这个问题呢。 问题:如何实现延时? 解决方向:recovery_min_apply_delay ...

易野
27分钟前
17
0
jpgraph 实例文档

下载 在官方网站http://www.aditus.nu/jpgraph/ 下载jpgraph,其中1.X系列是用于PHP4的,2.X系列是用于PHP5的。 安装 将下载的得到的jpgraph压缩文件解压至相应的路径。 配置 首先需要注意的...

osc_2ch77h9m
28分钟前
9
0
画IDC状态趋势图

[背景]公司以前对IDC状态的测试都是通过perl+crond结合,向指定某IDC的IP发送icmp包,并将其结果保存到test.log下,对于后斯的分析,是采取手工的方式(格式化数据,结合excel),这样操作下...

osc_moibnxyj
28分钟前
13
0
整理性能计数器注释

[前话]收集性能计数器注释,以备使用! [内容] 1 % Processor Time (Processor _Total) 指处理器用来执行非闲置线程时间的百分比。计算方法是,度量处理器用来执行空闲线程的时间,然后用 10...

osc_5nscij7v
30分钟前
12
0
你想要的WinForm界面开发教程在这里 - 如何设置较厚的表格边框

下载DevExpress v20.1完整版 DevExpress Winforms Controls 内置140多个UI控件和库,完美构建流畅、美观且易于使用的应用程序。想要体验?点击下载>> 应用程序的外观随时代发展不断变化,自厚...

FILA6666
30分钟前
9
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部