Freigeben über


EntityKey Klasse

Definition

Stellt eine permanente Referenz auf ein Objekt bereit, das eine Instanz eines Entitätstyps ist.

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>
[<System.Runtime.Serialization.DataContract(IsReference=true)>]
[<System.Serializable>]
type EntityKey = class
    interface IEquatable<EntityKey>
Public NotInheritable Class EntityKey
Implements IEquatable(Of EntityKey)
Vererbung
EntityKey
Attribute
Implementiert

Beispiele

In diesen Beispielen wird gezeigt, wie Sie einen EntityKeyerstellen und verwenden.

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 (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);
    }
}

Hinweise

EntityKey-Objekte sind unveränderlich, d. h. sie können nach ihrer Erstellung nicht geändert werden.

Weitere Informationen finden Sie unter Arbeiten mit Entitätsschlüsseln.

Konstruktoren

EntityKey()

Initialisiert eine neue Instanz der EntityKey-Klasse.

EntityKey(String, IEnumerable<EntityKeyMember>)

Initialisiert eine neue Instanz der EntityKey-Klasse mit einem Entitätenmengennamen und einer IEnumerable<T>-Auflistung von EntityKeyMember-Objekten.

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

Initialisiert eine neue Instanz der EntityKey-Klasse mit einem Entitätenmengennamen und einer generischen KeyValuePair-Auflistung.

EntityKey(String, String, Object)

Initialisiert eine neue Instanz der EntityKey-Klasse mit einem Entitätenmengennamen und einem spezifischen Entitätsschlüsselpaar.

Felder

EntityNotValidKey

Ein einfacher EntityKey, der eine Entität identifiziert, die bei einer fehlgeschlagenen TREAT-Operation erstellt wurde.

NoEntitySetKey

Ein Singleton-EntityKey, durch den eine schreibgeschützte Entität identifiziert wird.

Eigenschaften

EntityContainerName

Ruft den Namen des Entitätscontainers ab oder legt diesen fest.

EntityKeyValues

Ruft die diesem EntityKey zugeordneten Schlüsselwerte ab oder legt diese fest.

EntitySetName

Ruft den Namen der Entitätenmenge ab oder legt diesen fest.

IsTemporary

Ruft einen Wert ab, der angibt, ob der EntityKey temporär ist.

Methoden

Equals(EntityKey)

Gibt einen Wert zurück, der angibt, ob diese Instanz gleich einem angegebenen EntityKey ist.

Equals(Object)

Gibt einen Wert zurück, der angibt, ob diese Instanz gleich einem angegebenen Objekt ist.

GetEntitySet(MetadataWorkspace)

Ruft die Entitätenmenge für diesen Entitätsschlüssel vom angegebenen Metadaten-Arbeitsbereich ab.

GetHashCode()

Fungiert als Hashfunktion für das aktuelle EntityKey-Objekt. GetHashCode() eignet sich zur Verwendung in Hashalgorithmen und -datenstrukturen, z. B. in einer Hashtabelle.

GetType()

Ruft den Type der aktuellen Instanz ab.

(Geerbt von Object)
MemberwiseClone()

Erstellt eine flache Kopie des aktuellen Object.

(Geerbt von Object)
OnDeserialized(StreamingContext)

Hilfsmethode zur Deserialisierung eines EntityKey.

OnDeserializing(StreamingContext)

Hilfsmethode zur Deserialisierung eines EntityKey.

ToString()

Gibt eine Zeichenfolge zurück, die das aktuelle Objekt darstellt.

(Geerbt von Object)

Operatoren

Equality(EntityKey, EntityKey)

Vergleicht zwei EntityKey-Objekte.

Inequality(EntityKey, EntityKey)

Vergleicht zwei EntityKey-Objekte.

Gilt für: