EntityKey Osztály

Definíció

Tartós hivatkozást biztosít egy entitástípushoz tartozó objektumra.

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)
Öröklődés
EntityKey
Attribútumok
Megvalósítás

Példák

Ezek a példák bemutatják, hogyan hozhat létre és használhat egy 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);
    }
}

Megjegyzések

Az EntityKey objektumok nem módosíthatók, vagyis a felépítés után nem módosíthatók.

További információ: Entitáskulcsok használata.

Konstruktorok

Name Description
EntityKey()

Inicializálja a EntityKey osztály új példányát.

EntityKey(String, IEnumerable<EntityKeyMember>)

Inicializálja az EntityKey osztály új példányát egy entitáskészlet nevével és egy IEnumerable<T> objektumgyűjteménysel EntityKeyMember .

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

Inicializálja az EntityKey osztály új példányát egy entitáskészlet nevével és egy általános KeyValuePair gyűjteménysel.

EntityKey(String, String, Object)

Inicializálja az EntityKey osztály új példányát egy entitáskészlet nevével és egy adott entitáskulcs-párral.

Mezők

Name Description
EntityNotValidKey

Egy sikertelen EntityKey művelet eredményeként létrejött entitás egyszerű azonosítása.

NoEntitySetKey

Egyetlenton, EntityKey amellyel egy írásvédett entitást azonosít.

Tulajdonságok

Name Description
EntityContainerName

Lekéri vagy beállítja az entitástároló nevét.

EntityKeyValues

Lekéri vagy beállítja a hozzá társított EntityKeykulcsértékeket.

EntitySetName

Lekéri vagy beállítja az entitáskészlet nevét.

IsTemporary

Olyan értéket kap, amely jelzi, hogy az EntityKey ideiglenes-e.

Metódusok

Name Description
Equals(EntityKey)

Egy értéket ad vissza, amely jelzi, hogy ez a példány egyenlő-e egy megadott EntityKeyértékkel.

Equals(Object)

Olyan értéket ad vissza, amely jelzi, hogy ez a példány egyenlő-e egy adott objektummal.

GetEntitySet(MetadataWorkspace)

Lekéri az entitáskulcshoz beállított entitást a megadott metaadat-munkaterületről.

GetHashCode()

Az aktuális EntityKey objektum kivonatfüggvényeként szolgál. GetHashCode() alkalmas algoritmusok és adatstruktúrák, például kivonattáblák kivonatolására.

GetType()

Lekéri az Type aktuális példányt.

(Öröklődés forrása Object)
MemberwiseClone()

Az aktuális Objectpéldány sekély másolatát hozza létre.

(Öröklődés forrása Object)
OnDeserialized(StreamingContext)

Segédmetódus, amely egy EntityKey.

OnDeserializing(StreamingContext)

Segédmetódus, amely egy EntityKey.

ToString()

Az aktuális objektumot jelképező sztringet ad vissza.

(Öröklődés forrása Object)

Operátorok

Name Description
Equality(EntityKey, EntityKey)

Két EntityKey objektumot hasonlít össze.

Inequality(EntityKey, EntityKey)

Két EntityKey objektumot hasonlít össze.

A következőre érvényes: