Freigeben über


EntityKey Klasse

Definition

Stellt einen dauerhaften Verweis 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 eine 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 (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

Die EntityKey Objekte sind unveränderlich, d. h., nachdem sie konstruiert wurden, können sie nicht mehr geändert werden.

Konstruktoren

Name Beschreibung
EntityKey()

Initialisiert eine neue Instanz der EntityKey-Klasse.

EntityKey(String, IEnumerable<EntityKeyMember>)

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

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

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

EntityKey(String, String, Object)

Initialisiert eine neue Instanz der EntityKey Klasse mit einem Entitätssatznamen und einem bestimmten Entitätsschlüsselpaar.

Felder

Name Beschreibung
EntityNotValidKey

Eine einfache EntityKey Identifizierung einer Entität, die aus einem fehlgeschlagenen TREAT-Vorgang resultierte.

NoEntitySetKey

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

Eigenschaften

Name Beschreibung
EntityContainerName

Dient zum Abrufen oder Festlegen des Namens des Entitätscontainers.

EntityKeyValues

Dient zum Abrufen oder Festlegen der Schlüsselwerte, die diesem EntityKeyzugeordnet sind.

EntitySetName

Dient zum Abrufen oder Festlegen des Namens des Entitätssatzes.

IsTemporary

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

Methoden

Name Beschreibung
Equals(EntityKey)

Gibt einen Wert zurück, der angibt, ob diese Instanz einem angegebenen EntityKeyWert entspricht.

Equals(Object)

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

GetEntitySet(MetadataWorkspace)

Ruft den Entitätssatz für diesen Entitätsschlüssel aus dem angegebenen Metadatenarbeitsbereich ab.

GetHashCode()

Dient als Hashfunktion für das aktuelle EntityKey Objekt. GetHashCode() eignet sich für Hashingalgorithmen und Datenstrukturen wie eine Hashtabelle.

GetType()

Ruft die Type der aktuellen Instanz ab.

(Geerbt von Object)
MemberwiseClone()

Erstellt eine flache Kopie der aktuellen Object.

(Geerbt von Object)
OnDeserialized(StreamingContext)

Hilfsmethode, die zum Deserialisieren eines EntityKey.

OnDeserializing(StreamingContext)

Hilfsmethode, die zum Deserialisieren eines EntityKey.

ToString()

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

(Geerbt von Object)

Operatoren

Name Beschreibung
Equality(EntityKey, EntityKey)

Vergleicht zwei EntityKey-Objekte.

Inequality(EntityKey, EntityKey)

Vergleicht zwei EntityKey-Objekte.

Gilt für: