EntityKey Klass
Definition
Viktigt
En del information gäller för förhandsversionen av en produkt och kan komma att ändras avsevärt innan produkten blir allmänt tillgänglig. Microsoft lämnar inga garantier, uttryckliga eller underförstådda, avseende informationen som visas här.
Innehåller en beständig referens till ett objekt som är en instans av en entitetstyp.
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)
- Arv
-
EntityKey
- Attribut
- Implementeringar
Exempel
De här exemplen visar hur du skapar och använder en 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);
}
}
Kommentarer
Objekten EntityKey är oföränderliga, dvs. när de har konstruerats kan de inte ändras.
Mer information finns i Arbeta med entitetsnycklar.
Konstruktorer
| Name | Description |
|---|---|
| EntityKey() |
Initierar en ny instans av EntityKey klassen. |
| EntityKey(String, IEnumerable<EntityKeyMember>) |
Initierar en ny instans av EntityKey klassen med ett entitetsuppsättningsnamn och en IEnumerable<T> samling EntityKeyMember objekt. |
| EntityKey(String, IEnumerable<KeyValuePair<String,Object>>) |
Initierar en ny instans av EntityKey klassen med ett entitetsuppsättningsnamn och en allmän KeyValuePair samling. |
| EntityKey(String, String, Object) |
Initierar en ny instans av EntityKey klassen med ett entitetsuppsättningsnamn och ett specifikt entitetsnyckelpar. |
Fält
| Name | Description |
|---|---|
| EntityNotValidKey |
En enkel EntityKey identifiering av en entitet som orsakades av en misslyckad TREAT-åtgärd . |
| NoEntitySetKey |
En singleton EntityKey med vilken en skrivskyddad entitet identifieras. |
Egenskaper
| Name | Description |
|---|---|
| EntityContainerName |
Hämtar eller anger namnet på entitetscontainern. |
| EntityKeyValues |
Hämtar eller anger de nyckelvärden som är associerade med den här EntityKey. |
| EntitySetName |
Hämtar eller anger namnet på entitetsuppsättningen. |
| IsTemporary |
Hämtar ett värde som anger om är EntityKey tillfälligt. |
Metoder
| Name | Description |
|---|---|
| Equals(EntityKey) |
Returnerar ett värde som anger om den här instansen är lika med en angiven EntityKey. |
| Equals(Object) |
Returnerar ett värde som anger om den här instansen är lika med ett angivet objekt. |
| GetEntitySet(MetadataWorkspace) |
Hämtar entiteten som angetts för den här entitetsnyckeln från den angivna metadataarbetsytan. |
| GetHashCode() |
Fungerar som en hash-funktion för det aktuella EntityKey objektet. GetHashCode() är lämplig för hash-algoritmer och datastrukturer, till exempel en hash-tabell. |
| GetType() |
Hämtar den aktuella instansen Type . (Ärvd från Object) |
| MemberwiseClone() |
Skapar en ytlig kopia av den aktuella Object. (Ärvd från Object) |
| OnDeserialized(StreamingContext) |
Hjälpmetod som används för att deserialisera en EntityKey. |
| OnDeserializing(StreamingContext) |
Hjälpmetod som används för att deserialisera en EntityKey. |
| ToString() |
Returnerar en sträng som representerar det aktuella objektet. (Ärvd från Object) |
Operatorer
| Name | Description |
|---|---|
| Equality(EntityKey, EntityKey) |
Jämför två EntityKey objekt. |
| Inequality(EntityKey, EntityKey) |
Jämför två EntityKey objekt. |