zoukankan      html  css  js  c++  java
  • Dataentity call stack dynamics 365

    Th keep it here for my own reference.

      

    My notes:

    Here is a sequence of method’s calls during export:

    1. initValue
    2. validateField
    3. validateWrite
    4. update
    4.1. doUpdate
    4.1.1. persistEntity
    4.1.1.1. doPersistEntity
    4.1.1.1.1. initializeDataSources
    4.1.1.1.1.1. initializeEntityDataSource
    Note: initializeDataSource is called once for each DataSource in Entity.
    4.1.1.1.2. mapEntityToDataSources
    Note: initializeDataSource is called once for each DataSource in Entity.
    4.1.1.1.3. saveDataSources
    4.1.1.1.3.1. updateEntityDataSource
    4.1.1.1.4. mapEntityToDataSource (maybe for another record)
    4.1.1.1.5. saveDataSources
    4.1.1.1.5.1. updateEntityDataSource for update operation and (insertEntityDataSource for insert)
    4.1.1.1.5.1.1. mapDataSourceToEntity
    4.1.1.1.5.1.2. doSaveDataSource
    4.1.1.1.5.1.2.1. updateDataSource
    4.1.1.1.5.1.2.1.1. preupInsertDataSource
    4.1.1.1.5.1.2.1.1.1. validateWrite of table
    5.0 postLoad


    Here are some method’s calls during Import:


    defaultCTQuery
    copyCustomStagingToTarget
    postGetStagingData
    preTargetProcessSetBased
    postTargetProcess
    1. The postLoad method is called also by import! Since postLoad is the recommended place to set values for the virtual fields, this potentially slow-down the import process unnecessarily.
    2. Be careful by using the postTargetProcess method! This method is called at the end of EACH thread/task-bundle if you are using the “Import threshold record count” option.
    3. Previously, you could add postTargetProcess only to a newly created entity, but now you can extend any entity using CoC

    Extension is simple.

    [ExtensionOf(tableStr(DataEntity))] final public class DataEntity_Extension {

        public static void postTargetProcess(DMFDefinitionGroupExecution _dmfDefinitionGroupExecution)     {         // Do no call next         //logic here     } }

    Please note that this can be done only MDM scenarios but not via ODATA because ODATA updates, inserts records row by row and there is no post event\method to use. You might wish to use OData action to perform post actions on records.

  • 相关阅读:
    和为S的两个数字
    和为S的连续正数序列
    两个链表的第一个公共结点
    删除链表中重复的结点
    常用开发工具的安装(JDK、IDEA、Tomcat、Maven、Mysql和Nodepad++)——实习日志7.10
    蓄水池取样(转)
    prepare statement
    ProxySQL Getting started
    架构收录
    服务开机自启动
  • 原文地址:https://www.cnblogs.com/lingdanglfw/p/15546121.html
Copyright © 2011-2022 走看看