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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 13.08.2007, 08:02   #1  
Sequel is offline
Sequel
Участник
 
53 / 13 (1) ++
Регистрация: 17.06.2005
Адрес: Новокузнецк
Экспорт из журнала базы данных
Привет, народ!
Вопрос: можно ли скопировать в буфер, либо экспортировать каким-либо другим способом информацию из журнала базы данных, из правой части окна - там где выводится список полей измененной записи со старыми и новыми их значениями
Старый 13.08.2007, 10:04   #2  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Вот такой job посмотрите. Я форматированием не занимался.
Но думаю суть будет ясна и привести к божескому виду сможете.

X++:
static void tutorial_ShowDataBaseLogAsString(Args _args)
{
    TextBuffer      textBuffer = new TextBuffer();
    SysDataBaseLog  dataBaseLog;
    List            dataList;
    ListEnumerator  dataListEnumerator;
    str             data;
    container       tmpCon;
    FieldId         fieldId;
    ;
    while select dataBaseLog
        where dataBaseLog.table == tableNum(CustTable) &&
              dataBaseLog.LogType == DataBaseLogType::Insert &&
              dataBaseLog.createdDate == 06\08\2007
    {
        textBuffer.appendText(strFmt("\nОписание: %1, Тип записи: %2, Таблица: %3\n\n", dataBaseLog.Description, dataBaseLog.LogType, tableId2Name(dataBaseLog.table)));
        dataList = dataBaseLog.getDataAslist();
        dataListEnumerator = dataList.getEnumerator();
        while (dataListEnumerator.moveNext())
        {
            tmpCon = dataListEnumerator.current();
            fieldId = conpeek(tmpCon, 1);
            textBuffer.appendText(strFmt("Поле: %1\n", fieldId2name(dataBaseLog.table, fieldId)));
            textBuffer.appendText(strFmt("Новое значение: %1\n", dataBaseLog.contents2Str(conpeek(tmpCon, 2), fieldId)));
            textBuffer.appendText(strFmt("Старое значение: %1\n", dataBaseLog.contents2Str(conpeek(tmpCon, 3), fieldId)));
        }
    }
    textBuffer.toFile("C:\\test.txt");
}
Старый 13.08.2007, 11:20   #3  
Gustav is offline
Gustav
Moderator
Аватар для Gustav
SAP
Лучший по профессии 2009
 
1,858 / 1152 (42) ++++++++
Регистрация: 24.01.2006
Адрес: Санкт-Петербург
Записей в блоге: 19
А я вот еще какую фигнюшку замастырил для работы с текущим содержанием этого окна. Перекрываем метод doubleClick у контрола ListView формы SysDatabaseLog, т.е. полный путь к новому методу будет такой: \Forms \SysDatabaseLog \Designs \Design \[Tab:Tab] \[TabPage:History] \ListView:List \Methods \doubleClick.

В этот метод вставляем следующий код:
X++:
public void doubleClick()
{
    int i;
    container c;
;
    for (i=1; i<= conlen(DBHistory.Data); i++)
    {
        c = conpeek(DBHistory.Data, i);
        info(strfmt( '%1 -- %2 -- %3', 
             fieldId2Name(DBHistory.Table, conpeek(c,1)), 
             conpeek(c,2), conpeek(c,3) ));
    }
}
Теперь выполняем даблклик на этом ListView и непустые строчки списка насыпаются в infolog, откуда их можно копипастить.
Старый 14.08.2007, 07:26   #4  
Sequel is offline
Sequel
Участник
 
53 / 13 (1) ++
Регистрация: 17.06.2005
Адрес: Новокузнецк
Круто! всем спасибо за советы
 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Принципы построения базы данных Гужанов Павел DAX: Администрирование 11 05.09.2008 16:47
Утилиты для работы с журналом базы данных vc DAX: База знаний и проекты 0 10.05.2008 17:40
Тормозит Экспорт/Импорт данных st_msav DAX: Администрирование 28 01.08.2006 15:52
Нужен запрет на изменения данных журнала переноса после его распечатки ATimTim DAX: Программирование 4 19.01.2005 12:16
Уменьшение базы данных Axapta Writer DAX: Администрирование 13 15.09.2003 16:53

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

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

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