共用方式為


UpdateFunction (EntityTypeMapping)

ModificationFunctionMapping 項目中的 UpdateFunction 項目,在 Entity Data Model (EDM) 中是做為 EntityTypeMapping 項目的子項目,會識別用於更新或修改現有實體的預存程序。

為了要更新實體,UpdateFunction 項目會將儲存結構描述中實體的屬性對應到資料庫中預存程序的參數。預存程序會修改儲存區中資料型別的執行個體。

範例

在下列範例中,UpdateFunction 項目對應的預存程序,會修改 Adventureworks 銷售模型中 SalesOrderDetail 實體的執行個體。UpdateFunction 項目的每個 ScalarProperty 子項目,會將儲存模型中 SalesOrderDetail 實體的屬性 (Property) 對應到預存程序中的參數。為了對應這些實體,ScalarProperty 子項目會使用這些屬性 (Attribute):

  • Name 屬性 (Attribute) 會識別要對應之 SalesOrderDetail 實體的屬性 (Property)。

  • ParameterName 屬性 (Attribute) 會識別 SalesOrderDetail 實體屬性 (Property) 要對應的預存程序參數。

  • Version 屬性 (Attribute) 會指定使用從資料庫讀取的原始資料做為資料,或是使用可能已經由用戶端程式碼變更過的目前資料做為資料。

除了 ScalarProperty 子項目之外,UpdateFunction 項目包含的 AssociationEnd 項目會對應正在修改中的實體可能會參考的關聯。如需詳細資訊,請參閱 AssociationEnd (EntityTypeMapping)

  <UpdateFunction
     FunctionName="AdventureWorksModel.Store.UpdateSalesOrderDetail" >
        <ScalarProperty Name="OrderQty" ParameterName="OrderQty"  Version="Current"/>
        <ScalarProperty Name="SalesOrderDetailID"
           ParameterName="SalesOrderDetailID" Version="Current"/>
      <AssociationEnd
         AssociationSet="FK_SalesOrderDetail_SalesOrderHeader_SalesOrderID"
    From="SalesOrderDetail" To="SalesOrderHeader">
        <ScalarProperty Name="SalesOrderID"
          ParameterName="SalesOrderID" Version="Current" />
       </AssociationEnd>
  </UpdateFunction>

另請參閱

工作

HOW TO:定義具有預存程序的模型 (Entity Framework)

概念

預存程序支援 (Entity Framework)
ModificationFunctionMapping (AssociationSetMapping)
DeleteFunction (EntityTypeMapping)
InsertFunction (EntityTypeMapping)