EntityKey EntityKey EntityKey EntityKey Class

Definition

Stellt eine permanente Referenz auf ein Objekt bereit, das eine Instanz eines Entitätstyps ist.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)
Vererbung
EntityKeyEntityKeyEntityKeyEntityKey
Attribute
Implementiert

Beispiele

Diese Beispiele basieren auf dem AdventureWorks Sales-Modell.These examples are based on the AdventureWorks Sales Model. In den Beispielen wird gezeigt, wie ein EntityKeyerstellt und verwendet wird.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

Hinweise

EntityKey-Objekte sind unveränderlich, d. h. sie können nach ihrer Erstellung nicht geändert werden.The EntityKey objects are immutable; that is, after they are constructed they cannot be modified.

Weitere Informationen finden Sie unter Arbeiten mit Entitäts Schlüsseln.For more information, see Working with Entity Keys.

Konstruktoren

EntityKey() EntityKey() EntityKey() EntityKey()

Initialisiert eine neue Instanz der EntityKey-Klasse.Initializes a new instance of the EntityKey class.

EntityKey(String, IEnumerable<EntityKeyMember>) EntityKey(String, IEnumerable<EntityKeyMember>) EntityKey(String, IEnumerable<EntityKeyMember>) EntityKey(String, IEnumerable<EntityKeyMember>)

Initialisiert eine neue Instanz der EntityKey-Klasse mit einem Entitätenmengennamen und einer IEnumerable<T>-Auflistung von EntityKeyMember-Objekten.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>>) EntityKey(String, IEnumerable<KeyValuePair<String,Object>>) EntityKey(String, IEnumerable<KeyValuePair<String,Object>>) EntityKey(String, IEnumerable<KeyValuePair<String,Object>>)

Initialisiert eine neue Instanz der EntityKey-Klasse mit einem Entitätenmengennamen und einer generischen KeyValuePair-Auflistung.Initializes a new instance of the EntityKey class with an entity set name and a generic KeyValuePair collection.

EntityKey(String, String, Object) EntityKey(String, String, Object) EntityKey(String, String, Object) EntityKey(String, String, Object)

Initialisiert eine neue Instanz der EntityKey-Klasse mit einem Entitätenmengennamen und einem spezifischen Entitätsschlüsselpaar.Initializes a new instance of the EntityKey class with an entity set name and specific entity key pair.

Felder

EntityNotValidKey EntityNotValidKey EntityNotValidKey EntityNotValidKey

Eine einfache EntityKey-Klasse, die eine Entität identifiziert, die bei einer fehlgeschlagenen TREAT-Operation erstellt wurde.A simple EntityKey identifying an entity that resulted from a failed TREAT operation.

NoEntitySetKey NoEntitySetKey NoEntitySetKey NoEntitySetKey

Ein Singleton-EntityKey, durch den eine schreibgeschützte Entität identifiziert wird.A singleton EntityKey by which a read-only entity is identified.

Eigenschaften

EntityContainerName EntityContainerName EntityContainerName EntityContainerName

Ruft den Namen des Entitätscontainers ab oder legt diesen fest.Gets or sets the name of the entity container.

EntityKeyValues EntityKeyValues EntityKeyValues EntityKeyValues

Ruft die diesem EntityKey zugeordneten Schlüsselwerte ab oder legt diese fest.Gets or sets the key values associated with this EntityKey.

EntitySetName EntitySetName EntitySetName EntitySetName

Ruft den Namen der Entitätenmenge ab oder legt diesen fest.Gets or sets the name of the entity set.

IsTemporary IsTemporary IsTemporary IsTemporary

Ruft einen Wert ab, der angibt, ob der EntityKey temporär ist.Gets a value that indicates whether the EntityKey is temporary.

Methoden

Equals(EntityKey) Equals(EntityKey) Equals(EntityKey) Equals(EntityKey)

Gibt einen Wert zurück, der angibt, ob diese Instanz gleich einem angegebenen EntityKey ist.Returns a value that indicates whether this instance is equal to a specified EntityKey.

Equals(Object) Equals(Object) Equals(Object) Equals(Object)

Gibt einen Wert zurück, der angibt, ob diese Instanz gleich einem angegebenen Objekt ist.Returns a value that indicates whether this instance is equal to a specified object.

GetEntitySet(MetadataWorkspace) GetEntitySet(MetadataWorkspace) GetEntitySet(MetadataWorkspace) GetEntitySet(MetadataWorkspace)

Ruft die Entitätenmenge für diesen Entitätsschlüssel vom angegebenen Metadaten-Arbeitsbereich ab.Gets the entity set for this entity key from the given metadata workspace.

GetHashCode() GetHashCode() GetHashCode() GetHashCode()

Fungiert als Hashfunktion für das aktuelle EntityKey-Objekt.Serves as a hash function for the current EntityKey object. GetHashCode() eignet sich zur Verwendung in Hashalgorithmen und -datenstrukturen, z. B. in einer Hashtabelle.GetHashCode() is suitable for hashing algorithms and data structures such as a hash table.

GetType() GetType() GetType() GetType()

Ruft den Type der aktuellen Instanz ab.Gets the Type of the current instance.

(Inherited from Object)
MemberwiseClone() MemberwiseClone() MemberwiseClone() MemberwiseClone()

Erstellt eine flache Kopie des aktuellen Object.Creates a shallow copy of the current Object.

(Inherited from Object)
OnDeserialized(StreamingContext) OnDeserialized(StreamingContext) OnDeserialized(StreamingContext) OnDeserialized(StreamingContext)

Hilfsmethode zur Deserialisierung eines EntityKey.Helper method that is used to deserialize an EntityKey.

OnDeserializing(StreamingContext) OnDeserializing(StreamingContext) OnDeserializing(StreamingContext) OnDeserializing(StreamingContext)

Hilfsmethode zur Deserialisierung eines EntityKey.Helper method that is used to deserialize an EntityKey.

ToString() ToString() ToString() ToString()

Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt.Returns a string that represents the current object.

(Inherited from Object)

Operatoren

Equality(EntityKey, EntityKey) Equality(EntityKey, EntityKey) Equality(EntityKey, EntityKey) Equality(EntityKey, EntityKey)

Vergleicht zwei EntityKey-Objekte.Compares two EntityKey objects.

Inequality(EntityKey, EntityKey) Inequality(EntityKey, EntityKey) Inequality(EntityKey, EntityKey) Inequality(EntityKey, EntityKey)

Vergleicht zwei EntityKey-Objekte.Compares two EntityKey objects.

Gilt für: