EntityKey Třída

Definice

Poskytuje trvalý odkaz na objekt, který je instancí typu entity.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)
Dědičnost
EntityKey
Atributy
Implementuje

Příklady

Tyto příklady jsou založené na ukázkách produktů Microsoft SQL Server: databáze.These examples are based on the Microsoft SQL Server Product Samples: Database. Příklady ukazují, jak vytvořit a použít 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

Poznámky

Objekty EntityKey jsou neměnné; To znamená, že po jejich sestavení nelze upravovat.The EntityKey objects are immutable; that is, after they are constructed they cannot be modified.

Další informace najdete v tématu práce s klíči entit.For more information, see Working with Entity Keys.

Konstruktory

EntityKey()

Inicializuje novou instanci třídy EntityKey.Initializes a new instance of the EntityKey class.

EntityKey(String, IEnumerable<EntityKeyMember>)

Inicializuje novou instanci třídy EntityKey s názvem sady entit a kolekcí IEnumerable<T> objektů 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>>)

Inicializuje novou instanci třídy EntityKey s názvem sady entit a obecnou KeyValuePair kolekcí.Initializes a new instance of the EntityKey class with an entity set name and a generic KeyValuePair collection.

EntityKey(String, String, Object)

Inicializuje novou instanci třídy EntityKey s názvem sady entit a konkrétní dvojici klíčů entit.Initializes a new instance of the EntityKey class with an entity set name and specific entity key pair.

Pole

EntityNotValidKey

Jednoduchá EntityKey identifikující entitu, která je výsledkem neúspěšné operace považovat za neúspěšnou.A simple EntityKey identifying an entity that resulted from a failed TREAT operation.

NoEntitySetKey

Typ singleton EntityKey, pomocí kterého je identifikována entita, která je jen pro čtení.A singleton EntityKey by which a read-only entity is identified.

Vlastnosti

EntityContainerName

Získá nebo nastaví název kontejneru entity.Gets or sets the name of the entity container.

EntityKeyValues

Získá nebo nastaví hodnoty klíče přidružené k tomuto EntityKey.Gets or sets the key values associated with this EntityKey.

EntitySetName

Získá nebo nastaví název sady entit.Gets or sets the name of the entity set.

IsTemporary

Získá hodnotu, která označuje, zda je EntityKey dočasný.Gets a value that indicates whether the EntityKey is temporary.

Metody

Equals(EntityKey)

Vrátí hodnotu, která označuje, zda je tato instance rovna zadanému EntityKey.Returns a value that indicates whether this instance is equal to a specified EntityKey.

Equals(Object)

Vrací hodnotu, která určuje, zda je tato instance rovna zadanému objektu.Returns a value that indicates whether this instance is equal to a specified object.

GetEntitySet(MetadataWorkspace)

Načte sadu entit pro tento klíč entity z daného pracovního prostoru metadat.Gets the entity set for this entity key from the given metadata workspace.

GetHashCode()

Slouží jako funkce hash pro aktuální objekt EntityKey.Serves as a hash function for the current EntityKey object. GetHashCode() je vhodný pro algoritmy hash a datové struktury, jako je zatřiďovací tabulka.GetHashCode() is suitable for hashing algorithms and data structures such as a hash table.

GetType()

Získá Type aktuální instance.Gets the Type of the current instance.

(Zděděno od Object)
MemberwiseClone()

Vytvoří kopii aktuálního Objectbez podstruktury.Creates a shallow copy of the current Object.

(Zděděno od Object)
OnDeserialized(StreamingContext)

Pomocná metoda, která se používá k deserializaci EntityKey.Helper method that is used to deserialize an EntityKey.

OnDeserializing(StreamingContext)

Pomocná metoda, která se používá k deserializaci EntityKey.Helper method that is used to deserialize an EntityKey.

ToString()

Vrací řetězec, který představuje aktuální objekt.Returns a string that represents the current object.

(Zděděno od Object)

Operátory

Equality(EntityKey, EntityKey)

Porovná dva objekty EntityKey.Compares two EntityKey objects.

Inequality(EntityKey, EntityKey)

Porovná dva objekty EntityKey.Compares two EntityKey objects.

Platí pro