Exportar (0) Imprimir
Expandir todo
Este artículo proviene de un motor de traducción automática. Mueva el puntero sobre las frases del artículo para ver el texto original. Más información.
Traducción
Original

EntityContainer (Clase)

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

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

public sealed class EntityContainer : GlobalItem

El tipo EntityContainer expone los siguientes miembros.

  NombreDescripción
Propiedad públicaBaseEntitySetsObtiene una lista de los conjuntos de entidades y de asociaciones que EntityContainer incluye.
Propiedad públicaBuiltInTypeKindObtiene la clase de tipo integrado de EntityContainer. (Invalida a MetadataItem.BuiltInTypeKind).
Propiedad públicaDocumentationObtiene o establece la documentación asociada a este tipo. (Se hereda de MetadataItem).
Propiedad públicaFunctionImportsEspecifica 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 la propiedad CommandText equivalente asignada a una entidad y sus propiedades.
Propiedad públicaMetadataPropertiesObtiene la lista de propiedades del tipo actual. (Se hereda de MetadataItem).
Propiedad públicaNameObtiene el nombre de este objeto EntityContainer.
Arriba

  NombreDescripción
Método públicoEquals(Object)Determina si el objeto especificado es igual al objeto actual. (Se hereda de Object).
Método públicoGetEntitySetByNameDevuelve un objeto EntitySet utilizando el nombre especificado del conjunto de entidades.
Método públicoGetHashCode Sirve como una función hash para un tipo en particular. (Se hereda de Object).
Método públicoGetRelationshipSetByNameDevuelve un objeto RelationshipSet utilizando el nombre especificado del conjunto de relaciones.
Método públicoGetType Obtiene el Typede la instancia actual. (Se hereda de Object).
Método públicoToStringDevuelve el nombre de este objeto EntityContainer. (Invalida a Object.ToString()).
Método públicoTryGetEntitySetByNameDevuelve un objeto EntitySet utilizando el nombre especificado del conjunto de entidades.
Método públicoTryGetRelationshipSetByNameDevuelve un objeto RelationshipSet utilizando el nombre especificado del conjunto de relaciones.
Arriba

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 entre tablas y/o claves que conservan datos para las aplicaciones basadas en el modelo. Para obtener más información sobre 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 de la conexión y, a continuación, cómo utilizarla para recuperar información sobre los contenedores de entidades en el modelo de datos especificado. Observe que el área de trabajo de metadatos es un componente de 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 método GetEntityContainers obtiene una colección de contenedores de entidades y, a continuación, la recorre en iteración para obtener cada conjunto de entidades y conjunto de asociaciones en el contenedor especificado. En el ejemplo de código se utiliza 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

Compatible con: 4.5.2, 4.5.1, 4.5, 4, 3.5 SP1

.NET Framework Client Profile

Compatible con: 4

Windows Phone 8.1, Windows Phone 8, Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008 (no se admite el rol Server Core), Windows Server 2008 R2 (se admite el rol Server Core con SP1 o versiones posteriores; no se admite Itanium)

.NET Framework no admite todas las versiones de todas las plataformas. Para obtener una lista de las versiones compatibles, vea Requisitos de sistema de .NET Framework.

Todos los miembros static (Shared en Visual Basic) públicos de este tipo son seguros para la ejecución de subprocesos. No se garantiza que los miembros de instancias sean seguros para la ejecución de subprocesos.

Adiciones de comunidad

AGREGAR
Mostrar:
© 2014 Microsoft