Hibernate的学习之路二十二(一对多的级联删除)

前言

   这篇主要说明了级联删除,比较繁琐需要举例子说明

 

代码

技术分析之级联删除

1. 先来给大家在数据库中演示含有外键的删除客户功能,那么SQL语句是会报出错误的
    * 例如:delete from customers where cid = 1;

2. 如果使用Hibernate框架直接删除客户的时候,测试发现是可以删除的(这里需要配置级联删除,如果不配置也是报错的)

3. 上述的删除是普通的删除,那么也可以使用级联删除,注意:级联删除也是有方向性的!!
    * <many-to-one cascade="delete" />

 

 

现在举个例子

 

A 是一      B C是多。

 

 

以下是没有配置delete字段。删除的结果是A删除了,B和C里的外键都修改成null。

	/**
	 * 测试:删除客户,客户下有2个联系人
	 */
	@Test
	public void run6(){
		Session session = HibernateUtils.getCurrentSession();
		Transaction tr = session.beginTransaction();
		// 先查询1号客户
		Customer c1 = session.get(Customer.class, 1L);
		session.delete(c1);
		
		tr.commit();
	}

 

 

 

以下是设置了A(一)的delete。结果是A删除了,B和C删除了

	/**
	 * 测试级联删除,删除客户,级联删除客户下的联系人
	 */
	@Test
	public void run7(){
		Session session = HibernateUtils.getCurrentSession();
		Transaction tr = session.beginTransaction();
		// 先查询1号客户
		Customer c1 = session.get(Customer.class, 1L);
		session.delete(c1);
		tr.commit();
	}

 


以下是设置了B(多)的delete。结果是A删除了,B删除了, A的外键修改成null。

	@Test
	public void run8(){
		Session session = HibernateUtils.getCurrentSession();
		Transaction tr = session.beginTransaction();
		
		Linkman man = session.get(Linkman.class, 1L);
		session.delete(man);
		
		tr.commit();
	}

 

以下是一和多都设置了delete,结果是A和B和C都删除了。

	/**
	 * 测试级联删除
	 */
	@Test
	public void run9(){
		Session session = HibernateUtils.getCurrentSession();
		Transaction tr = session.beginTransaction();
		Linkman man = session.get(Linkman.class, 1L);
		session.delete(man);
		tr.commit();
	}

 

其他

在企业中,对删除是非常重视的,不要随意删除,有些只是在数据库中多添加了一个字段,来判断用户那边是否删除了这个数据。

 

留着数据可以进行分析,或者有功能是回收站功能,可以还原的功能。

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值