EntityKey Klas
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
Biedt een duurzame verwijzing naar een object dat een exemplaar van een entiteitstype is.
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)
- Overname
-
EntityKey
- Kenmerken
- Implementeringen
Voorbeelden
In deze voorbeelden ziet u hoe u een 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);
}
}
Opmerkingen
De EntityKey objecten zijn onveranderbaar. Dat wil gezegd, nadat ze zijn samengesteld, kunnen ze niet meer worden gewijzigd.
Zie Werken met entiteitssleutels voor meer informatie.
Constructors
| Name | Description |
|---|---|
| EntityKey() |
Initialiseert een nieuw exemplaar van de EntityKey klasse. |
| EntityKey(String, IEnumerable<EntityKeyMember>) |
Initialiseert een nieuw exemplaar van de EntityKey klasse met een entiteitssetnaam en een IEnumerable<T> verzameling EntityKeyMember objecten. |
| EntityKey(String, IEnumerable<KeyValuePair<String,Object>>) |
Initialiseert een nieuw exemplaar van de EntityKey klasse met een entiteitssetnaam en een algemene KeyValuePair verzameling. |
| EntityKey(String, String, Object) |
Initialiseert een nieuw exemplaar van de EntityKey klasse met een entiteitssetnaam en een specifiek entiteitssleutelpaar. |
Velden
| Name | Description |
|---|---|
| EntityNotValidKey |
Een eenvoudige EntityKey identificatie van een entiteit die het gevolg is van een mislukte TREAT-bewerking . |
| NoEntitySetKey |
Een singleton EntityKey waarmee een entiteit met het kenmerk Alleen-lezen wordt geïdentificeerd. |
Eigenschappen
| Name | Description |
|---|---|
| EntityContainerName |
Hiermee haalt u de naam van de entiteitscontainer op of stelt u deze in. |
| EntityKeyValues |
Hiermee worden de sleutelwaarden opgehaald of ingesteld die aan deze EntityKeysleutel zijn gekoppeld. |
| EntitySetName |
Hiermee haalt u de naam van de entiteitsset op of stelt u deze in. |
| IsTemporary |
Hiermee wordt een waarde opgehaald die aangeeft of het EntityKey tijdelijk is. |
Methoden
| Name | Description |
|---|---|
| Equals(EntityKey) |
Retourneert een waarde die aangeeft of dit exemplaar gelijk is aan een opgegeven EntityKey. |
| Equals(Object) |
Retourneert een waarde die aangeeft of dit exemplaar gelijk is aan een opgegeven object. |
| GetEntitySet(MetadataWorkspace) |
Hiermee haalt u de entiteitsset voor deze entiteitssleutel op uit de opgegeven metagegevenswerkruimte. |
| GetHashCode() |
Fungeert als een hash-functie voor het huidige EntityKey object. GetHashCode() is geschikt voor hash-algoritmen en gegevensstructuren, zoals een hash-tabel. |
| GetType() |
Hiermee haalt u de Type huidige instantie op. (Overgenomen van Object) |
| MemberwiseClone() |
Hiermee maakt u een ondiepe kopie van de huidige Object. (Overgenomen van Object) |
| OnDeserialized(StreamingContext) |
Helpermethode die wordt gebruikt voor het deserialiseren van een EntityKey. |
| OnDeserializing(StreamingContext) |
Helpermethode die wordt gebruikt voor het deserialiseren van een EntityKey. |
| ToString() |
Retourneert een tekenreeks die het huidige object vertegenwoordigt. (Overgenomen van Object) |
Operators
| Name | Description |
|---|---|
| Equality(EntityKey, EntityKey) |
Vergelijkt twee EntityKey objecten. |
| Inequality(EntityKey, EntityKey) |
Vergelijkt twee EntityKey objecten. |