英語で読む

次の方法で共有


EntityKey クラス

定義

エンティティ型のインスタンスであるオブジェクトへの持続的な参照を提供します。

[System.Runtime.Serialization.DataContract(IsReference=true)]
[System.Serializable]
public sealed class EntityKey : IEquatable<System.Data.EntityKey>
継承
EntityKey
属性
実装

これらの例では、 を作成して使用する方法を 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);
    }
}

注釈

EntityKey オブジェクトは不変です。つまり、構築後は変更できません。

詳細については、「 エンティティ キーの操作」を参照してください。

コンストラクター

EntityKey()

EntityKey クラスの新しいインスタンスを初期化します。

EntityKey(String, IEnumerable<EntityKeyMember>)

エンティティ セット名および EntityKeyMember オブジェクトの IEnumerable<T> コレクションを使用して、EntityKey クラスの新しいインスタンスを初期化します。

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

エンティティ セット名およびジェネリック型の KeyValuePair コレクションを使用して、EntityKey クラスの新しいインスタンスを初期化します。

EntityKey(String, String, Object)

エンティティ セット名および特定のエンティティ キーのペアを使用して、EntityKey クラスの新しいインスタンスを初期化します。

フィールド

EntityNotValidKey

失敗した TREAT 演算で生成されたエンティティを識別する単純な EntityKey

NoEntitySetKey

読み取り専用エンティティを識別する単一の EntityKey

プロパティ

EntityContainerName

エンティティ コンテナーの名前を取得または設定します。

EntityKeyValues

この EntityKey に関連付けられているキーの値を取得または設定します。

EntitySetName

エンティティ セットの名前を取得または設定します。

IsTemporary

EntityKey が一時的かどうかを示す値を取得します。

メソッド

Equals(EntityKey)

このインスタンスが、指定された EntityKey と等価であるかどうかを示す値を返します。

Equals(Object)

このインスタンスが、指定されたオブジェクトと等価であるかどうかを示す値を返します。

GetEntitySet(MetadataWorkspace)

このエンティティ キーのエンティティ セットを、指定されたメタデータ ワークスペースから取得します。

GetHashCode()

現在の EntityKey オブジェクトのハッシュ関数として機能します。 GetHashCode() は、ハッシュ アルゴリズムでの使用、およびハッシュ テーブルのようなデータ構造での使用に適しています。

GetType()

現在のインスタンスの Type を取得します。

(継承元 Object)
MemberwiseClone()

現在の Object の簡易コピーを作成します。

(継承元 Object)
OnDeserialized(StreamingContext)

EntityKey のシリアル化解除に使用されるヘルパー メソッド。

OnDeserializing(StreamingContext)

EntityKey のシリアル化解除に使用されるヘルパー メソッド。

ToString()

現在のオブジェクトを表す文字列を返します。

(継承元 Object)

演算子

Equality(EntityKey, EntityKey)

2 つの EntityKey オブジェクトを比較します。

Inequality(EntityKey, EntityKey)

2 つの EntityKey オブジェクトを比較します。

適用対象

製品 バージョン
.NET Framework 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1