现在的位置: 首页 > 综合 > 正文

实体之间的级联关系

2018年01月29日 ⁄ 综合 ⁄ 共 2150字 ⁄ 字号 评论关闭

                                 实体之间的级联关系

      我们在以前的七种关系映射中经常会在注释中看到如下方法:cascade(),它表示级联,也就是有关联的一些实体,
当我们对其中的一些进行操作的时候,与它相关联的实体应该怎么办。这样时候,就需要我们定义cascade的属性了,cascade一共有五种属性,我们
可以用其中的一种,也可以用其中的多种混合,其中可用的属性如下:
public enum CascadeType
{
   ALL, PERSIST,
MERGE, REMOVE,
REFRESH
}

属性中ALL表示所有的级联,如果选了它就表示所有的级联了,也就不必选其它的了。下面我们一个一个来讲讲它们的用处吧:

1,PERSIST
PERSIST的意思就是持久的意思,它表示当我们对其中一个实体进行持久化操作的时候,与它相关联的也同样持久化进数据库,也就是执行insert动作。这样在我们保存的时候,只需要保存一个实体就可以了,与它相关联的实体也会被同时保存。

Customer cust = new Customer( );
Address address = new Address( );
cust.setAddress(address);

entityManager.persist(cust);


上面的代码中,我们只需要持久化cust就可以了,与cust相关联的Address会自动被保存进数据库。如果我们没有指定PERSIST关联,那么我
们就需要再调用entityManager.persist(address)来保存Address,这样就比较麻烦了。

2,MERGE
MERGE就是合并的意思,也就是把当前的实体BEAN的内容合并到数据库里面去,如果当前实体BEAN在数据库里面没有相应的记录,则它会自动插入新的记录,在这一点上,它和PERSIST比较相似。

cust.setName("William");
cust.getAddress( ).setCity("Boston");

entityManager.merge(cust);


以上代码中,当我们把cust的名字改了,并且把地址里面的城市名也改了以后,我们合并到数据库的时候,Address表中的数据也一样会跟着更新,那如
果我们新加一个地址进去呢?会怎么样呢?结果还是一样的,如果EntityManager发现没有这条数据时,它为了把主体合并到数据库里面去,它就会插
入一个新的实体到数据库中。在我们在一对多的时候,可以看到这一点:

Phone phone = new Phone( );
phone.setNumber("617-666-6666");

cust.getPhoneNumbers( ).add(phone);
Customer newCust=entityManager.merge(cust);


这里加了一个新的号码,然后我们合并cust,结果新的phone也被插入数据库了。在这里我们要注意的一点是,在这里只有返回值newCust
才是在当前持久化上下文相关联的BEAN,而做为参数传进去的cust并不是,它可以只是一个简单的脱离了EntityManager管理的类。

3,Delete
Delete顾名思义就是删除的意思,当我们删除一个实体的时候,我们标志了Delete关联的实体都会被相应的删除。

Customer cust = entityManager.find(Customer.class, 1);
entityManager.remove(cust);

当我们删除一个cust的时候,它相关联的phone,address也会一并被删除。

4,REFRESH
REFRESH就是更新的意思,它有点类似于MERGE,但是它是和MERGE相反的,我们MERGE的时候,会把当前实体的值合并到数据库中,而当我们REFRESH的时候,却是把据库的最新值更新到我们的实体BEAN中。

Customer cust ;
entityManager.refresh(cust); // address would be refreshed too


上面,如果address在数据库中被别的程序更改了,那么当这句话调用结束之后,cust里面的address也跟着更新了,在这里,cust
和address的数据不会被写入数据库,相反的,数据库的最新值将被写入到它们里面。当我们不需要把数据写入数据库,而只需要从数据库里面取最新的时
候,这个方法是很有用的。比如数据库某些列是数据库触发某个事件自动更新的,而不需要我们自己去更新,就可以用这个,这个时候,最好不是在这一列上加如下
注释以确保此列数据不会被我们人为地更改:
@Column (insertable=false, updatable=false...

5,ALL
ALL就是全部的意思,它表示以上四种关联它都拥有。


实并不是所有的场合都适合用关联,因为有些时候,一些数据的更新并不影响别的数据,这个时候就不需要关联了,比如,我们不希望多对多的时候,如果人改国籍
不应该把原来的国家的实体删掉吧。所以在我们使用关联的时候,一定要想清楚,是不是实体之间有相辅相成的关系或者缺一不可的关系。其实使用关联只是让我们
偷偷懒而已,因为它可以让我们少写一些相关的代码

抱歉!评论已关闭.