EntityKey Classe

Definizione

Fornisce un riferimento durevole a un oggetto che rappresenta un'istanza di un tipo di entità.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)
Ereditarietà
EntityKey
Attributi
Implementazioni

Esempi

Questi esempi sono basati sul modello Sales di AdventureWorks.These examples are based on the AdventureWorks Sales Model. Gli esempi illustrano come creare e usare un oggetto 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

Commenti

Gli oggetti EntityKey non sono modificabili, ossia non possono essere modificati dopo essere stati costruiti.The EntityKey objects are immutable; that is, after they are constructed they cannot be modified.

Per ulteriori informazioni, vedere utilizzo delle chiavi di entità.For more information, see Working with Entity Keys.

Costruttori

EntityKey()

Inizializza una nuova istanza della classe EntityKey.Initializes a new instance of the EntityKey class.

EntityKey(String, IEnumerable<EntityKeyMember>)

Inizializza una nuova istanza della classe EntityKey con un nome del set di entità e una raccolta IEnumerable<T> di oggetti 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>>)

Inizializza una nuova istanza della classe EntityKey con un nome del set di entità e una raccolta di KeyValuePair generica.Initializes a new instance of the EntityKey class with an entity set name and a generic KeyValuePair collection.

EntityKey(String, String, Object)

Inizializza una nuova istanza della classe EntityKey con un nome del set di entità e una coppia di chiavi di entità specifica.Initializes a new instance of the EntityKey class with an entity set name and specific entity key pair.

Campi

EntityNotValidKey

Oggetto EntityKey semplice che identifica un'entità risultante da un'operazione TREAT non riuscita.A simple EntityKey identifying an entity that resulted from a failed TREAT operation.

NoEntitySetKey

Un oggetto EntityKey singleton mediante il quale viene identificata un'entità di sola lettura.A singleton EntityKey by which a read-only entity is identified.

Proprietà

EntityContainerName

Ottiene o imposta il nome del contenitore di entità.Gets or sets the name of the entity container.

EntityKeyValues

Ottiene o imposta i valori di chiave associati a questo oggetto EntityKey.Gets or sets the key values associated with this EntityKey.

EntitySetName

Ottiene o imposta il nome del set di entità.Gets or sets the name of the entity set.

IsTemporary

Ottiene un valore che indica se l'oggetto EntityKey è temporaneo.Gets a value that indicates whether the EntityKey is temporary.

Metodi

Equals(EntityKey)

Restituisce un valore che indica se questa istanza è uguale a un oggetto EntityKey specificato.Returns a value that indicates whether this instance is equal to a specified EntityKey.

Equals(Object)

Restituisce un valore che indica se questa istanza è uguale a un oggetto specificato.Returns a value that indicates whether this instance is equal to a specified object.

GetEntitySet(MetadataWorkspace)

Ottiene il set di entità per la chiave di entità presente nell'area di lavoro metadati specificata.Gets the entity set for this entity key from the given metadata workspace.

GetHashCode()

Viene utilizzato come funzione hash per l'oggetto EntityKey corrente.Serves as a hash function for the current EntityKey object. Il metodo GetHashCode() è adatto per algoritmi hash e strutture dei dati, ad esempio una tabella hash.GetHashCode() is suitable for hashing algorithms and data structures such as a hash table.

GetType()

Ottiene l'oggetto Type dell'istanza corrente.Gets the Type of the current instance.

(Ereditato da Object)
MemberwiseClone()

Crea una copia superficiale dell'oggetto Object corrente.Creates a shallow copy of the current Object.

(Ereditato da Object)
OnDeserialized(StreamingContext)

Metodo di supporto utilizzato per deserializzare un oggetto EntityKey.Helper method that is used to deserialize an EntityKey.

OnDeserializing(StreamingContext)

Metodo di supporto utilizzato per deserializzare un oggetto EntityKey.Helper method that is used to deserialize an EntityKey.

ToString()

Restituisce una stringa che rappresenta l'oggetto corrente.Returns a string that represents the current object.

(Ereditato da Object)

Operatori

Equality(EntityKey, EntityKey)

Confronta due oggetti EntityKey.Compares two EntityKey objects.

Inequality(EntityKey, EntityKey)

Confronta due oggetti EntityKey.Compares two EntityKey objects.

Si applica a