Este artículo se tradujo automáticamente. Para ver el artículo en inglés, active la casilla Inglés. Además, puede mostrar el texto en inglés en una ventana emergente si mueve el puntero del mouse sobre el texto.
Traducción
Inglés

Clase EntityContainer

 

Representa un contenedor de entidades en un modelo conceptual. Un EntityContainer es una agrupación lógica de conjuntos de entidades y de conjuntos de asociaciones.

Espacio de nombres:   System.Data.Metadata.Edm
Ensamblado:  System.Data.Entity (en System.Data.Entity.dll)

System.Object
  System.Data.Metadata.Edm.MetadataItem
    System.Data.Metadata.Edm.GlobalItem
      System.Data.Metadata.Edm.EntityContainer

public sealed class EntityContainer : GlobalItem

NombreDescripción
System_CAPS_pubpropertyBaseEntitySets

Obtiene una lista de los conjuntos de entidades y los conjuntos de asociaciones que este EntityContainer incluye.

System_CAPS_pubpropertyBuiltInTypeKind

Obtiene la modalidad del tipo integrado para EntityContainer.(Invalida MetadataItem.BuiltInTypeKind).

System_CAPS_pubpropertyDocumentation

Obtiene o establece la documentación asociada a este tipo.(Heredado de MetadataItem).

System_CAPS_pubpropertyFunctionImports

Especifica una colección de elementos de EdmFunction. Cada función contiene los detalles de un procedimiento almacenado que existe en la base de datos o equivalente CommandText que se asigna a una entidad y sus propiedades.

System_CAPS_pubpropertyMetadataProperties

Obtiene la lista de propiedades del tipo actual.(Heredado de MetadataItem).

System_CAPS_pubpropertyName

Obtiene el nombre de EntityContainer.

NombreDescripción
System_CAPS_pubmethodEquals(Object)

Determina si el objeto especificado es igual al objeto actual.(Heredado de Object).

System_CAPS_pubmethodGetEntitySetByName(String, Boolean)

Devuelve un objeto EntitySet mediante el uso del nombre especificado para el conjunto de entidades.

System_CAPS_pubmethodGetHashCode()

Sirve como la función hash predeterminada.(Heredado de Object).

System_CAPS_pubmethodGetRelationshipSetByName(String, Boolean)

Devuelve un objeto RelationshipSet mediante el uso del nombre especificado para el conjunto de relaciones.

System_CAPS_pubmethodGetType()

Obtiene el Type de la instancia actual.(Heredado de Object).

System_CAPS_pubmethodToString()

Devuelve el nombre de este EntityContainer.(Invalida Object.ToString()).

System_CAPS_pubmethodTryGetEntitySetByName(String, Boolean, EntitySet)

Devuelve un objeto EntitySet mediante el uso del nombre especificado para el conjunto de entidades.

System_CAPS_pubmethodTryGetRelationshipSetByName(String, Boolean, RelationshipSet)

Devuelve un objeto RelationshipSet mediante el uso del nombre especificado para el conjunto de relaciones.

En el nivel conceptual, la clase EntityContainer representa un contenedor que se asignará a un objeto de base de datos en el esquema de metadatos de almacenamiento. En el nivel de almacenamiento, la clase EntityContainer representa una descripción de las relaciones de tabla y/o de clave que conservan los datos para las aplicaciones basadas en el modelo. Para obtener más información acerca de los contenedores de entidades en un modelo conceptual, vea Entity Containers (EDM).

En el ejemplo de código siguiente se muestra cómo obtener un área de trabajo de metadatos desde la conexión que y cómo se usa después dicha área de trabajo para recuperar información acerca de los contenedores de entidades en el modelo de datos especificado. Observe que el área de trabajo de metadatos es un componente del servicio en tiempo de ejecución que proporciona compatibilidad para recuperar los metadatos.

En el ejemplo de código se usa un CSpace y un SSpace para especificar el modelo. CSpace representa el nombre predeterminado del modelo conceptual. SSpace representa el nombre predeterminado del modelo de almacenamiento.

El GetEntityContainers método obtiene una colección de contenedores de entidades y, a continuación, recorre en iteración la colección para obtener cada conjunto de entidades y un conjunto de asociaciones en el contenedor especificado. En el ejemplo de código se usa el modelo de AdventureWorks que se proporciona en el tema Adventure Works Model (EDM). Para obtener un ejemplo del archivo de configuración de la aplicación, vea Adventure Works Object Model in Applications (EDM).

using System;
using System.Data;
using System.Data.EntityClient;
using System.Data.Metadata.Edm;
using System.Collections.ObjectModel;

class GetEntityContainerExample
{
  static void Main()
  {
    try
    {
       // Establish a connection to the underlying data provider by 
       // using the connection string specified in the config file.
       using (EntityConnection connection =
          new EntityConnection("Name=AdventureWorksEntities"))
       {
         // Open the connection.
         connection.Open();

         // Access the metadata workspace.
         MetadataWorkspace workspace = 
            connection.GetMetadataWorkspace();

         // Get the entity containers in the conceptual model.
         GetEntityContainers(workspace, DataSpace.CSpace);

         // Get the entity containers in the storage model.
             GetEntityContainers(workspace, DataSpace.SSpace);
       }
    }
    catch (MetadataException exceptionMetadata)
    {
      Console.WriteLine("MetadataException: {0}", 
                       exceptionMetadata.Message);
    }
    catch (System.Data.MappingException exceptionMapping)
    {
      Console.WriteLine("MappingException: {0}",
                       exceptionMapping.Message);
    }
  }

  public static void GetEntityContainers(
      MetadataWorkspace workspace, DataSpace model)
  {
    // Get a collection of the entity containers.
    ReadOnlyCollection<EntityContainer> containers = 
         workspace.GetItems<EntityContainer>(model);

    // Iterate through the collection to get each entity container.
    foreach (EntityContainer container in containers)
    {
       Console.WriteLine("EntityContainer Name: {0} ", 
                        container.Name);

       // EntitySetBase is a super type for 
       // EntitySets and RelationshipSets. 
       // Iterate through the collection to get each EntitySetBase.
       foreach (EntitySetBase baseSet in container.BaseEntitySets)
       {
          // Check if this instance is an EntitySet.
          if (baseSet is EntitySet)
          {
             Console.WriteLine(
                "  EntitySet Name: {0} , EntityType Name: {1} ",
                baseSet.Name, baseSet.ElementType.FullName);
          }

         // RelationshipSet is a super type for AssociationSet.
         // Check if this instance is an AssociationSet.
         if (baseSet is AssociationSet)
         {
            Console.WriteLine(
               "  AssociationSet Name: {0} , " +
               "AssociationType Name: {1} ",
                baseSet.Name, baseSet.ElementType.FullName);

            // Get the AssociationSet.
            AssociationSet associationSet = 
                  baseSet as AssociationSet;

            // Iterate through the collection to get 
            // each AssociatedSetEnd.
            foreach (AssociationSetEnd end in 
               associationSet.AssociationSetEnds)
            {
               Console.WriteLine(
                  "   EntitySet Name: {0} , Name: {1} ",
                  end.EntitySet, end.Name);
            }
         }
      }
    }
  }
}

.NET Framework
Disponible desde 3.5

Cualquier miembro ( Compartido en Visual Basic) estático público de este tipo es seguro para subprocesos. No se garantiza que los miembros de instancia sean seguros para subprocesos.

Volver al principio
Mostrar: