Hibernate的注解many-to-one

項目中一個實例:

   最近使用annotation做hibernate映射,有两张表乘客(Passanger)表 和订单(VacationOrder )表,乘客表和订单表是ManyToOne,业务只需要从订单表出发设置不同乘客,根据乘客查看预订的订单,采用双向关联,ManyToOne 和Many-To-One 

 

VacationOrder 對象中关于乘客的注解:

VacationOrder 对象继承自Order:

@Entity
@Table(name = "VAC_ORDER")
public class VacationOrder extends Order:

 

 /**
  * 乘客
  */
 @OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY, mappedBy = "order")
 @JoinColumn(name = "orderId")
 private List<Passanger> passangers = new ArrayList<Passanger>();

 

 

在乘客的Passager中关于订单的注解:

@Entity
@GenericGenerator(name = "seq_gen", strategy = "org.hibernate.id.enhanced.SequenceStyleGenerator", parameters = {
  @Parameter(name = "sequence_name", value = "seq_Passanger"),
  @Parameter(name = "initial_value", value = "100000") })
public class Passanger extends Consumer ;

 

 

 @ManyToOne(cascade = CascadeType.REFRESH, fetch = FetchType.LAZY)
 @JoinColumn(name = "orderId", insertable = false, updatable = false)
 private Order order;

 


 @Column(name = "orderId")
 private Long orderId;

 

 

注意:在Passager 对象中将属性 order和orderId映射同一张表中统一字段,目的这样可以查询时适当的减少相关的查询.

 

 

 

在订单中相应的乘客发生变化时,保存订单可以更改乘客的信息.

如果修改乘客的信息是:

 保存订单时,更给关联中的对象不起作用

查看以下帮助文档:

总结以下:

(1)在乘客表中order和orderId,同时映射一张表的时候,必须设置insertable = false, updatable = false否则将报错,order对象必须设置inserte = false, update = false.

(2)在关联的订单中乘客发生变化时必须将关联的Id设置为null.否则数据库中的乘客的信息不会发生变化.

 

 

 

 

 

 

 

 

@ManyToOne(cascade = { CascadeType.PERSIST,CascadeType.MERGE}) 它始终是不对VacationOrder 进行更新和新增操作,如果改成@ManyToOne(cascade = { CascadeType.ALL})就可以更新和新增VacationOrder 表,但删除操作是我业务不允许有的。

官方解释如下:

CascadeType.PERSIST:级联新增
CascadeType.MERGE:级联合并
CascadeType.REFRESH:级联刷新
CascadeType.REMOVE:级联删除
CascadeType.ALL:以上四种都是

在Passanger表关系定义如下:
@ManyToOne(cascade = { CascadeType.PERSIST,CascadeType.MERGE})
@JoinColumn(name = "orderId")

但我在后台方法测试时,如果订单信息修改或新建,保存到乘客表中,医院信息不会级联更新或新增,级联关系不起作用 .

 

CascadeType.PERSIST(级联新建),CascadeType.MERGE(级联合并),如果我把annotation方式改为CascadeType.ALL,级联更新和新增就可以.

 



 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值