Compartir a través de


multiplicidad de extremo de asociación (Entity Data Model)

La multiplicidad de extremo de asociación define el número de instancias de tipo de entidad que puede haber en un extremo de una asociación.

Una multiplicidad de extremo de asociación puede tener uno de los valores siguientes:

  • uno (1): indica que existe exactamente una instancia de tipo de entidad en el extremo de la asociación.

  • cero o uno (0..1): indica que pueden existir cero o una instancia de tipo de entidad en el extremo de la asociación.

  • varios (*): indica que pueden existir cero, una o varias instancias de tipo de entidad en el extremo de la asociación.

Normalmente, una asociación se caracteriza por sus multiplicidades de extremo de asociación. Por ejemplo, si los extremos de una asociación tienen multiplicidades uno (1) y varios (*), la asociación se denomina una asociación uno a varios. En el ejemplo siguiente, la asociación PublishedBy es una asociación uno a varios (un publicador publica muchos libros y un libro solo puede ser publicado por un publicador). La asociación WrittenBy es una asociación varios a varios (un libro puede tener varios autores y un autor puede escribir varios libros).

Ejemplo

El diagrama siguiente muestra un modelo conceptual con dos asociaciones: PublishedBy y WrittenBy. Los extremos de asociación para la asociación PublishedBy son los tipos de entidad Book y Publisher. La multiplicidad del extremo Publisher es uno (1) y la multiplicidad del extremo Book es muchos (*).

Modelo del ejemplo

ADO.NET Entity Framework usa un lenguaje específico de dominio (DSL) denominado lenguaje de definición de esquemas conceptuales (CSDL) para definir los modelos conceptuales. El código CSDL siguiente define la asociación PublishedBy mostrada en el diagrama anterior:

<Association Name="PublishedBy">
      <End Type="BooksModel.Book" Role="Book" Multiplicity="*" />
      <End Type="BooksModel.Publisher" Role="Publisher" Multiplicity="1" />
    </Association>

Vea también

Conceptos

Conceptos clave de Entity Data Model
Entity Data Model