ObjectStateManager.GetObjectStateEntry Metoda

Definicja

Zwraca element ObjectStateEntry dla określonego obiektu lub wpisu relacji.

Przeciążenia

GetObjectStateEntry(EntityKey)

Zwraca wartość ObjectStateEntry dla obiektu lub wpisu relacji z określonym kluczem.

GetObjectStateEntry(Object)

Zwraca wartość ObjectStateEntry dla określonego obiektu.

GetObjectStateEntry(EntityKey)

Zwraca wartość ObjectStateEntry dla obiektu lub wpisu relacji z określonym kluczem.

public:
 System::Data::Objects::ObjectStateEntry ^ GetObjectStateEntry(System::Data::EntityKey ^ key);
public System.Data.Objects.ObjectStateEntry GetObjectStateEntry (System.Data.EntityKey key);
member this.GetObjectStateEntry : System.Data.EntityKey -> System.Data.Objects.ObjectStateEntry
Public Function GetObjectStateEntry (key As EntityKey) As ObjectStateEntry

Parametry

key
EntityKey

Element EntityKey.

Zwraca

ObjectStateEntry

ObjectStateEntry Odpowiadający danej EntityKeywartości .

Wyjątki

Gdy key wartość to null.

Jeśli nie można odnaleźć określonego key elementu w menedżerze stanu.

W obiekcie nie istnieje żadna jednostka o określonej EntityKey nazwie ObjectStateManager.

Przykłady

Przykład w tym temacie jest oparty na Microsoft SQL Server Przykłady produktów: Baza danych. Przykład pobiera wartość ObjectStateEntry dla danej EntityKey z elementu ObjectStateManager. Następnie pobiera bieżącą wartość SalesOrderHeader.PurchaseOrderNumber właściwości, zmienia wartość właściwości i wylicza za pośrednictwem kolekcji zmodyfikowanych właściwości.

// Specify the order to update.
int orderId = 43680;

using (AdventureWorksEntities context =
    new AdventureWorksEntities())
{
    try
    {
        var order = (from o in context.SalesOrderHeaders
                     where o.SalesOrderID == orderId
                     select o).First();

        // Change the status of an existing order.
        order.Status = 1;

        // Delete the first item in the order.
        context.DeleteObject(order.SalesOrderDetails.First());

        // 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 = 0,
            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);

        // Get the ObjectStateEntry for the order.
        ObjectStateEntry stateEntry =
            context.ObjectStateManager
            .GetObjectStateEntry(order);
        Console.WriteLine("State before SaveChanges() is called: {0}",
            stateEntry.State.ToString());

        // Save changes in the object context to the database.
        int changes = context.SaveChanges();

        Console.WriteLine("State after SaveChanges() is called: {0}",
            stateEntry.State.ToString());

        Console.WriteLine(changes.ToString() + " changes saved!");
        Console.WriteLine("Updated item for order ID: "
            + order.SalesOrderID.ToString());

        // Iterate through the collection of SalesOrderDetail items.
        foreach (SalesOrderDetail item in order.SalesOrderDetails)
        {
            Console.WriteLine("Item ID: "
                + item.SalesOrderDetailID.ToString() + "  Product: "
                + item.ProductID.ToString() + "  Quantity: "
                + item.OrderQty.ToString());
        }
    }
    catch (UpdateException ex)
    {
        Console.WriteLine(ex.ToString());
    }
}
' Specify the order to update. 
Dim orderId As Integer = 43680

Using context As New AdventureWorksEntities()
    Try
        Dim order = (From o In context.SalesOrderHeaders
            Where o.SalesOrderID = orderId
            Select o).First()

        ' Change the status of an existing order. 
        order.Status = 1

        ' Delete the first item in the order. 
        context.DeleteObject(order.SalesOrderDetails.First())

        ' 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)

        ' Get the ObjectStateEntry for the order. 
        Dim stateEntry As ObjectStateEntry = context.ObjectStateManager.GetObjectStateEntry(order)
        Console.WriteLine("State before SaveChanges() is called: {0}", stateEntry.State.ToString())

        ' Save changes in the object context to the database. 
        Dim changes As Integer = context.SaveChanges()

        Console.WriteLine("State after SaveChanges() is called: {0}", stateEntry.State.ToString())

        Console.WriteLine(changes.ToString() & " changes saved!")
        Console.WriteLine("Updated item for order ID: " & order.SalesOrderID.ToString())

        ' Iterate through the collection of SalesOrderDetail items. 
        For Each item As SalesOrderDetail In order.SalesOrderDetails
            Console.WriteLine("Item ID: {0}", item.SalesOrderDetailID.ToString())
            Console.WriteLine("Product: {0}", item.ProductID.ToString())
            Console.WriteLine("Quantity: {0}", item.OrderQty.ToString())
        Next
    Catch ex As UpdateException
        Console.WriteLine(ex.ToString())
    End Try
End Using

Uwagi

TryGetObjectStateEntry(EntityKey, ObjectStateEntry) Użyj metody , aby zwrócić ObjectStateEntry obiekt bez konieczności obsługi obiektu zgłoszonego InvalidOperationException przez metodę GetObjectStateEntry(EntityKey) .

Dotyczy

GetObjectStateEntry(Object)

Zwraca wartość ObjectStateEntry dla określonego obiektu.

public:
 System::Data::Objects::ObjectStateEntry ^ GetObjectStateEntry(System::Object ^ entity);
public System.Data.Objects.ObjectStateEntry GetObjectStateEntry (object entity);
member this.GetObjectStateEntry : obj -> System.Data.Objects.ObjectStateEntry
Public Function GetObjectStateEntry (entity As Object) As ObjectStateEntry

Parametry

entity
Object

Element Object , do którego należy pobrany ObjectStateEntry element.

Zwraca

ObjectStateEntry

ObjectStateEntry Odpowiadający danej Objectwartości .

Wyjątki

W obiekcie ObjectStateManagernie istnieje żadna jednostka dla określonej Object jednostki .

Uwagi

TryGetObjectStateEntry(Object, ObjectStateEntry) Użyj metody , aby zwrócić ObjectStateEntry obiekt bez konieczności obsługi obiektu zgłoszonego InvalidOperationException przez metodę GetObjectStateEntry(Object) .

Dotyczy