以客户和订单的关系为例,一个客户能发出多个订单,而一个订单(order)只能属于一个客户(customer)。从订单到客户的关联是多对一关联,这意味着每个订单对象都会引用一个客户对象,因此在订单类中应该定义一个客户类型的属性,来引用关联的客户对象。
从客户到订单是一对多的关联,这意味着每个客户对象会引用一组订单对象,因此在客户类中应该定义一个集合类型的属性,来引用所有关联的订单对象。
如果仅有从订单到客户的关联,或者仅有从客户到订单的关联,就称为单向关联。如果同时包含两种关联,就称为双向关联。
在关系数据库中,只存在外键参照关系,而且总是由many方参照one方,因此关系数据库实际上只支持多对一或一对一的单向关联。
文章目录
建立多对一单向关系
在类与类之间各种各样的关系中,多对一的单向关联关系和关系数据库中外键参照关系最匹配了。因此使用单向关联,通常选择从 Order 到 Customer 的多对一单向关联。在 Order 类中需要定义一个 customer 属性,而在 Customer 类中无须定义用于存放 Order 对象的集合属性。