首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >实体-Bean (JPA)中的单向关系

实体-Bean (JPA)中的单向关系
EN

Stack Overflow用户
提问于 2010-08-19 03:10:55
回答 2查看 7.6K关注 0票数 6

如何在EJB3.0 Entity-Beans (JPA)中建立单向关系?

例如,客户知道订单,但订单对客户没有任何方法。使用(@OneToMany或@OneToOne或@ManyToMany)

问候

EN

Stack Overflow用户

发布于 2010-08-19 04:40:14

暂时抛开“单向”不谈,可以对客户-订单关系进行建模,如下所示。

代码语言:javascript
运行
复制
@Entity
public class Customer {
  // ...
  @Id @GeneratedValue
  int id;
  @OneToMany(cascade = CascadeType.ALL, mappedBy = "customer")
  Set<Order> orders;
  // ...
}

@Entity
public class Order {
  // ...
  @ManyToOne(optional = false)
  Customer customer;
  // ...
}

这里我假设每个订单只有一个客户。在数据库中,Order表将有一个"customer_id“列,该列具有指向Customer表的"id”列的外键。DDL将如下所示。

代码语言:javascript
运行
复制
CREATE TABLE Customer (
  id INT NOT NULL,
  ...
  PRIMARY KEY (id)
);

CREATE TABLE Order (
  ...
  customer_id INT NOT NULL,
  ...
  FOREIGN KEY (customer_id) REFERENCES Customer (id)
);

尽管customer类包含一个订单集合,但这实际上不会以任何方式影响数据库结构;它只是检索/管理属于该客户的订单的一种方便方法。例如,您可以完全删除来自Customer的"orders“成员,而依靠查询来获取这些记录。

我想说的是,从数据库的角度来看,并不存在所谓的“单向”关系。提供的示例Java 将生成类,其中没有直接从Order对象获取Customer对象的方法,但是得到的数据库结构将是相同的(忽略列名的细微差别)。您总是可以通过查询的方式找到给定订单的客户。

票数 1
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/3515756

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档