前言
这篇主要说明了级联删除,比较繁琐需要举例子说明
代码
技术分析之级联删除
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();
}
其他
在企业中,对删除是非常重视的,不要随意删除,有些只是在数据库中多添加了一个字段,来判断用户那边是否删除了这个数据。
留着数据可以进行分析,或者有功能是回收站功能,可以还原的功能。