EntityKey Osztály
Definíció
Fontos
Egyes információk olyan, kiadás előtti termékekre vonatkoznak, amelyek a kiadásig még jelentősen módosulhatnak. A Microsoft nem vállal kifejezett vagy törvényi garanciát az itt megjelenő információért.
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. |