EntityKey Clase

Definición

Proporciona una referencia duradera a un objeto que es una instancia de un tipo de entidad.Provides a durable reference to an object that is an instance of an entity type.

public ref class EntityKey sealed : IEquatable<System::Data::EntityKey ^>
[System.Runtime.Serialization.DataContract(IsReference=true)]
[System.Serializable]
public sealed class EntityKey : IEquatable<System.Data.EntityKey>
type EntityKey = class
    interface IEquatable<EntityKey>
Public NotInheritable Class EntityKey
Implements IEquatable(Of EntityKey)
Herencia
EntityKey
Atributos
Implementaciones

Ejemplos

Estos ejemplos se basan en el modelo AdventureWorks Sales.These examples are based on the AdventureWorks Sales Model. En los ejemplos se muestra cómo crear y usar un EntityKey.The examples show you how to create and use an EntityKey.

using (AdventureWorksEntities context =
    new AdventureWorksEntities())
{
    Object entity = null;
    IEnumerable<KeyValuePair<string, object>> entityKeyValues =
        new KeyValuePair<string, object>[] {
            new KeyValuePair<string, object>("SalesOrderID", 43680) };

    // Create the  key for a specific SalesOrderHeader object. 
    EntityKey key = new EntityKey("AdventureWorksEntities.SalesOrderHeaders", entityKeyValues);

    // Get the object from the context or the persisted store by its key.
    if (context.TryGetObjectByKey(key, out entity))
    {
        Console.WriteLine("The requested " + entity.GetType().FullName +
            " object was found");
    }
    else
    {
        Console.WriteLine("An object with this key " +
            "could not be found.");
    }
}
Using context As New AdventureWorksEntities()
    Dim entity As Object = Nothing
    Dim entityKeyValues As IEnumerable(Of KeyValuePair(Of String, Object)) = _
        New KeyValuePair(Of String, Object)() {New KeyValuePair(Of String, Object)("SalesOrderID", 43680)}

    ' Create the key for a specific SalesOrderHeader object. 
    Dim key As New EntityKey("AdventureWorksEntities.SalesOrderHeaders", entityKeyValues)

    ' Get the object from the context or the persisted store by its key. 
    If context.TryGetObjectByKey(key, entity) Then
        Console.WriteLine("The requested " & entity.GetType().FullName & " object was found")
    Else
        Console.WriteLine("An object with this key could not be found.")
    End If
End Using
using (AdventureWorksEntities context =
    new AdventureWorksEntities())
{
    try
    {
        // Create the key that represents the order.
        EntityKey orderKey =
            new EntityKey("AdventureWorksEntities.SalesOrderHeaders",
                "SalesOrderID", orderId);

        // Create the stand-in SalesOrderHeader object
        // based on the specified SalesOrderID.
        SalesOrderHeader order = new SalesOrderHeader();
        order.EntityKey = orderKey;

        // Assign the ID to the SalesOrderID property to matche the key.
        order.SalesOrderID = (int)orderKey.EntityKeyValues[0].Value;

        // Attach the stand-in SalesOrderHeader object.
        context.SalesOrderHeaders.Attach(order);

        // Create a new SalesOrderDetail object.
        // You can use the static CreateObjectName method (the Entity Framework
        // adds this method to the generated entity types) instead of the new operator:
        // SalesOrderDetail.CreateSalesOrderDetail(1, 0, 2, 750, 1, (decimal)2171.2942, 0, 0,
        //                                         Guid.NewGuid(), DateTime.Today));
        SalesOrderDetail detail = new SalesOrderDetail
        {
            SalesOrderID = orderId,
            SalesOrderDetailID = 0,
            OrderQty = 2,
            ProductID = 750,
            SpecialOfferID = 1,
            UnitPrice = (decimal)2171.2942,
            UnitPriceDiscount = 0,
            LineTotal = 0,
            rowguid = Guid.NewGuid(),
            ModifiedDate = DateTime.Now
        };

        order.SalesOrderDetails.Add(detail);

        context.SaveChanges();
    }
    catch (InvalidOperationException)
    {
        Console.WriteLine("Ensure that the key value matches the value of the object's ID property.");
    }
    catch (UpdateException)
    {
        Console.WriteLine("An error has occurred. Ensure that an object with the '{0}' key value exists.",
        orderId);
    }
}
Using context As New AdventureWorksEntities()
    Try
        ' Create the key that represents the order. 
        Dim orderKey As New EntityKey("AdventureWorksEntities.SalesOrderHeaders", "SalesOrderID", orderId)

        ' Create the stand-in SalesOrderHeader object 
        ' based on the specified SalesOrderID. 
        Dim order As New SalesOrderHeader()
        order.EntityKey = orderKey

        ' Assign the ID to the SalesOrderID property to matche the key. 
        order.SalesOrderID = CInt(orderKey.EntityKeyValues(0).Value)

        ' Attach the stand-in SalesOrderHeader object. 
        context.SalesOrderHeaders.Attach(order)

        ' Create a new SalesOrderDetail object. 
        ' You can use the static CreateObjectName method (the Entity Framework 
        ' adds this method to the generated entity types) instead of the new operator: 
        ' SalesOrderDetail.CreateSalesOrderDetail(1, 0, 2, 750, 1, (decimal)2171.2942, 0, 0, 
        ' Guid.NewGuid(), DateTime.Today)); 
        Dim detail = New SalesOrderDetail With
        {
            .SalesOrderID = 0,
            .SalesOrderDetailID = 0,
            .OrderQty = 2,
            .ProductID = 750,
            .SpecialOfferID = 1,
            .UnitPrice = CDec(2171.2942),
            .UnitPriceDiscount = 0,
            .LineTotal = 0,
            .rowguid = Guid.NewGuid(),
            .ModifiedDate = DateTime.Now
        }

        order.SalesOrderDetails.Add(detail)

        context.SaveChanges()
    Catch generatedExceptionName As InvalidOperationException
        Console.WriteLine("Ensure that the key value matches the value of the object's ID property.")
    Catch generatedExceptionName As UpdateException
        Console.WriteLine("An error has occurred. Ensure that an object with the '{0}' key value exists.", orderId)
    End Try
End Using

Comentarios

Los objetos EntityKey son inmutables; es decir, una vez construidos, no se pueden modificar.The EntityKey objects are immutable; that is, after they are constructed they cannot be modified.

Para obtener más información, consulte trabajar con claves de entidad.For more information, see Working with Entity Keys.

Constructores

EntityKey()

Inicializa una nueva instancia de la clase EntityKey.Initializes a new instance of the EntityKey class.

EntityKey(String, IEnumerable<EntityKeyMember>)

Inicializa una nueva instancia de la clase EntityKey con un nombre de conjunto de entidades y una colección IEnumerable<T> de objetos EntityKeyMember.Initializes a new instance of the EntityKey class with an entity set name and an IEnumerable<T> collection of EntityKeyMember objects.

EntityKey(String, IEnumerable<KeyValuePair<String,Object>>)

Inicializa una nueva instancia de la clase EntityKey con un nombre de conjunto de entidades y una colección KeyValuePair genérica.Initializes a new instance of the EntityKey class with an entity set name and a generic KeyValuePair collection.

EntityKey(String, String, Object)

Inicializa una nueva instancia de la clase EntityKey con un nombre de conjunto de entidades y un par de nombre/valor de clave de entidad específico.Initializes a new instance of the EntityKey class with an entity set name and specific entity key pair.

Campos

EntityNotValidKey

EntityKey simple que identifica una entidad que es el resultado de una operación TREAT errónea.A simple EntityKey identifying an entity that resulted from a failed TREAT operation.

NoEntitySetKey

EntityKey singleton por la que se identifica una entidad de solo lectura.A singleton EntityKey by which a read-only entity is identified.

Propiedades

EntityContainerName

Obtiene o establece el nombre del contenedor de entidades.Gets or sets the name of the entity container.

EntityKeyValues

Obtiene o establece los valores de clave asociados al objeto EntityKey en cuestión.Gets or sets the key values associated with this EntityKey.

EntitySetName

Obtiene o establece el nombre del conjunto de entidades.Gets or sets the name of the entity set.

IsTemporary

Obtiene un valor que indica si la EntityKey es de solo lectura.Gets a value that indicates whether the EntityKey is temporary.

Métodos

Equals(EntityKey)

Devuelve un valor que indica si esta instancia es igual que una EntityKey especificada.Returns a value that indicates whether this instance is equal to a specified EntityKey.

Equals(Object)

Devuelve un valor que indica si esta instancia es igual que un objeto especificado.Returns a value that indicates whether this instance is equal to a specified object.

GetEntitySet(MetadataWorkspace)

Obtiene el conjunto de entidades para esta clave de entidad a partir del área de trabajo de metadatos especificada.Gets the entity set for this entity key from the given metadata workspace.

GetHashCode()

Sirve como función hash para el objeto EntityKey actual.Serves as a hash function for the current EntityKey object. El método GetHashCode() se puede utilizar en algoritmos hash y estructuras de datos, como una tabla hash.GetHashCode() is suitable for hashing algorithms and data structures such as a hash table.

GetType()

Obtiene el Type de la instancia actual.Gets the Type of the current instance.

(Heredado de Object)
MemberwiseClone()

Crea una copia superficial del Object actual.Creates a shallow copy of the current Object.

(Heredado de Object)
OnDeserialized(StreamingContext)

método del asistente que se usa para deserializar una EntityKey.Helper method that is used to deserialize an EntityKey.

OnDeserializing(StreamingContext)

método del asistente que se usa para deserializar una EntityKey.Helper method that is used to deserialize an EntityKey.

ToString()

Devuelve un valor de tipo string que representa el objeto actual.Returns a string that represents the current object.

(Heredado de Object)

Operadores

Equality(EntityKey, EntityKey)

Compara dos objetos EntityKey.Compares two EntityKey objects.

Inequality(EntityKey, EntityKey)

Compara dos objetos EntityKey.Compares two EntityKey objects.

Se aplica a