AXForum  
Вернуться   AXForum > Microsoft Dynamics AX > DAX: Программирование
All
Забыли пароль?
Зарегистрироваться Правила Справка Пользователи Сообщения за день Поиск

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 30.12.2010, 10:45   #23  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,440 / 1775 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
Для поиска удалённых данных, могу подкинуть один джобик.
X++:
// Восстанавливает в таблицу <toTable> записи удеалённые из таблицы <fromTable>
// !!! имена полей (и желательно их типы :) должны совпадать

static void RestoreToTable(TableId fromTableId, TableId toTableId, date fromDate, date toDate, UserId deletedBy = "")//, createdTransactionId _createdTransactionId)
{
    SysDataBaseLog  SysDataBaseLog;
    list            datalist;
    listEnumerator  enumerator;
    container       tmp;
    int             i;
    dictTable       toDictTable = new dictTable(toTableId);
    dictTable       fromDictTable = new dictTable(FromTableId);
    DictField       toDictField;
    DictField       fromDictField;
    FieldId         toFieldId;
    FieldId         fromFieldId;
    int             toCntFields;
    int             arrayCount;
    int             arrayIdx;
    FieldName       fromFieldName;
    FieldName       toFieldName;
    Common          Common;

    SysOperationProgress DialogProgress;
    int DialogProgress_cntAll;
    int DialogProgress_cnt = 0;
    ;

    DialogProgress = new SysOperationProgress();
    DialogProgress.setCaption("Восстановление удалённых записей");
    DialogProgress.setTotal(100);

    select count(RecId) from SysDataBaseLog
    where
        SysDataBaseLog.table == fromTableId
        && SysDataBaseLog.createdDateTime >= datetimeutil::newDateTime(fromDate, 0)
        && SysDataBaseLog.createdDateTime < datetimeutil::newDateTime(toDate + 1, 0)
        && (deletedBy == "" || SysDataBaseLog.createdBy == deletedBy)
        && SysDataBaseLog.LogType == DatabaseLogType::Delete
;//        && SysDataBaseLog.createdTransactionId == _createdTransactionId;

    DialogProgress_cntAll = SysDataBaseLog.RecId;

    while select SysDataBaseLog
    where
        SysDataBaseLog.table == fromTableId
        && SysDataBaseLog.createdDateTime >= datetimeutil::newDateTime(fromDate, 0)
        && SysDataBaseLog.createdDateTime < datetimeutil::newDateTime(toDate + 1, 0)
        && (deletedBy == "" || SysDataBaseLog.createdBy == deletedBy)
        && SysDataBaseLog.LogType == DatabaseLogType::Delete
//        && SysDataBaseLog.createdTransactionId == _createdTransactionId
    {
        DialogProgress.setText(strfmt
        (
            "Восстановленно записей: %1 из %2",
                    DialogProgress_cnt,
                    DialogProgress_cntAll
        ));

        Common = toDictTable.makeRecord();
        datalist = SysDataBaseLog.getDataAslist();
        enumerator = dataList.getEnumerator();
        while (enumerator.moveNext())
        {
            tmp = enumerator.current();
            fromFieldId = conpeek(tmp, 1);

            fromDictField = new dictField(fromDictTable.id(), fromFieldId);
            fromFieldName = fromDictField.name();

            toCntFields = toDictTable.fieldCnt();
            for (I = 1; I <= toCntFields; I++)
            {
                toDictField = new dictField(toDictTable.id(), toDictTable.fieldCnt2Id(I));
                toFieldId = toDictField.id();
                arrayCount = toDictField.arraySize();
                for (arrayIdx = 1; arrayIdx <= arrayCount; arrayIdx ++)
                {
                    toFieldId += 65536;
                    toDictField = new dictField(toDictTable.id(), toFieldId);
                    toFieldName = toDictField.name();
                    if (toFieldName == fromFieldName)
                    {
                        Common.(toDictField.id()) = conpeek(tmp, 2);
                    }
                }
            }
        }
        toFieldId = toDictTable.fieldName2Id("DeletedBy");
        if (toFieldId > 0) Common.(toFieldId) = SysDataBaseLog.createdBy;

        toFieldId = toDictTable.fieldName2Id("DeletedDateTime");
        if (toFieldId > 0) Common.(toFieldId) = SysDataBaseLog.createdDateTime;

        toFieldId = toDictTable.fieldName2Id("DeletedTransactionId");
        if (toFieldId > 0) Common.(toFieldId) = SysDataBaseLog.createdTransactionId;


        Common.insert();

        DialogProgress_cnt++;
        DialogProgress.setcount(DialogProgress_cnt*100/DialogProgress_cntAll);
    }
}
Рекомендую сделать дубликат InventTrans (правой кнопке по таблицув, пункт Дублировать) и восстановить данные туда. Также если в CopyOfInventTrans добавить поля DeletedBy, DeletedDateTime и DeletedTransactionId, то они также заполнятся
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
DynamicsAxSCM: The InventTrans table. Explore various field usages. Blog bot DAX Blogs 0 09.11.2010 19:10
Связь CustInvoiceJour и InventTrans Silphidae DAX: Программирование 19 29.10.2009 15:18
Query из 7 таблиц Cornflower DAX: Программирование 29 15.03.2007 11:27
aEremenko: Ресурс заблокирован, ждите... Blog bot DAX Blogs 0 28.10.2006 16:01
Связь таблиц InventTrans и PurchLine Pustik DAX: Программирование 2 25.11.2004 12:23

Ваши права в разделе
Вы не можете создавать новые темы
Вы не можете отвечать в темах
Вы не можете прикреплять вложения
Вы не можете редактировать свои сообщения

BB коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход

Рейтинг@Mail.ru
Часовой пояс GMT +3, время: 12:05.