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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 12.03.2021, 16:23   #1  
v.i.p.to is offline
v.i.p.to
Участник
 
14 / 10 (1) +
Регистрация: 24.07.2015
как экспортировать таблицу со всеми extendeddataType
Добрый день,
подскажите кто сталкивался в Аксапте 2009, необходимо перенести Таблицу с кучей полей и связей из 1 Аксапты в другую. Допустим таблица имеет 30 extendetDataType, чтобы выгрузить и их скопом.
Старый 12.03.2021, 16:39   #2  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,438 / 1775 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
Наверное не сложно сделать скрипт, который обойдёт в цикле все поля таблицы, найдёт все интересующие EDT и добавит их в проект.

Вот здесь можете посмотреть как программно работать с элементами проекта Собрать проект из перекрестных ссылок
Старый 13.03.2021, 10:53   #3  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Цитата:
Сообщение от v.i.p.to Посмотреть сообщение
Допустим таблица имеет 30 extendetDataType, чтобы выгрузить и их скопом.
Если половина из 30-и EDT - стандартные, их тоже будете выгружать? А еще EDT могут быть организованы в иерархию...
Старый 13.03.2021, 16:43   #4  
Raven Melancholic is offline
Raven Melancholic
Участник
Аватар для Raven Melancholic
Самостоятельные клиенты AX
Лучший по профессии 2015
 
2,164 / 1293 (48) ++++++++
Регистрация: 21.03.2005
Адрес: Москва-Петушки
Цитата:
Таблицу с кучей полей и связей
Сразу возникает вопрос не только про EDT.
  • Сами EDT могут расширять другие EDT, то есть нужно выгружать и родительские EDT (вплоть до самого базового).?
  • EDT может быть создано на основе BaseEnum (ну и поле может быть не на основе EDT, а BaseEnum), то есть нужны и BaseEnum?
  • На таблице могут быть relation и deleteaction на другие таблицы. Так как DAX2009, то на EDT могут быть relation на другие таблицы. Нужны ли эти таблицы? Если нужны, то нужны ли их EDT и далее по цепочке?
  • На EDT могут быть ссылки на lookup формы, их выгружать? А если в тех lokup формах есть другие таблицы, естественно, со своими свойствами, их выгружать?
  • На таблице могут быть заданы ссылки на формы и отчеты. Их выгружать? А если в тех формах и отчетах есть другие таблицы, естественно, со своими свойствами, их выгружать?
  • Ну и так далее, причем, с рекурсией.
В общем случае решения просто не существует или универсальное решение будет выгружать половину объектов AOT.

Последний раз редактировалось Raven Melancholic; 13.03.2021 в 16:45.
Старый 14.03.2021, 23:12   #5  
Dudnik Anton is offline
Dudnik Anton
Участник
 
9 / 24 (1) +++
Регистрация: 23.03.2004
Было, 10 лет назад.
Где же это поле?! (Form digger)
Старый 15.03.2021, 09:28   #6  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Цитата:
Сообщение от v.i.p.to Посмотреть сообщение
в Аксапте 2009, необходимо перенести Таблицу с кучей полей и связей из 1 Аксапты в другую. Допустим таблица имеет 30 extendetDataType, чтобы выгрузить и их скопом.
Согласен с S.Kuskov, gl00mie, Raven Melancholic, что хотелка странная и так делать не надо. Потому что в общем случае "скопом" может быть выгружено пол-аксапты.

Согласен с Dudnik Anton, что надо создавать проект. Но не согласен с тем, что проект должен автоматически наполняться. Ровно потому что в общем случае "скопом"...

Что же надо делать:

Автор модификации должен создать проект.

Цитата:
Проект в Аксапте - это ссылки на объекты АОТ, которые можно сгруппировать в рамках проекта произвольным образом
Нажмите на изображение для увеличения
Название: proj.PNG
Просмотров: 49
Размер:	64.4 Кб
ID:	13136

в разных командах существуют разные подходы и внутренние стандарты как именовать проекты (как правило, в имени будет номер задачи) и как группировать объекты внутри проекта.

технически, объекты в проект можно:
* создавать руками,
* переносить мышкой из AOT
* создавать группы с фильтром (в проект попадут все объекты АОТ подходящие под фильтр)
* создавать стандартным инструментом Advanced ProjectFilter
* создавать самописными инструментами типа того, что привел Dudnik Anton

Нажмите на изображение для увеличения
Название: filter.PNG
Просмотров: 45
Размер:	105.6 Кб
ID:	13137

фильтры в свойствах группы могут содержать специальные символы.
Значения символов описаны в хелпе к встроенной функии match
https://docs.microsoft.com/en-us/dyn...time-functions
Нажмите на изображение для увеличения
Название: properties.PNG
Просмотров: 48
Размер:	208.2 Кб
ID:	13138
Нажмите на изображение для увеличения
Название: properties2.PNG
Просмотров: 56
Размер:	118.3 Кб
ID:	13139

лично я предпочитаю, когда автор:
* продумывает названия объектов так, чтобы объекты было легко добавить в проект фильтрами (namespace для бедных)
* создает семантические группы с фильтрами
* продумывает какие объекты включить в проект, чтобы было одним движением переносить между аксаптами (как правило, из дев в тест, а затем в прод)
__________________
полезное на axForum, github, vk, coub.

Последний раз редактировалось mazzy; 15.03.2021 в 09:32.
Старый 15.03.2021, 12:40   #7  
DSPIC is offline
DSPIC
Боец
 
1,077 / 1243 (44) ++++++++
Регистрация: 11.04.2008
1. Вносим правку в стандартный метод \Classes\SysOpenNewWindowApplObject\runsysContextMenu
X++:
void runsysContextMenu(SysContextMenu _sysContextMenu)
{
    TreeNode aNode = _sysContextMenu.first();
    TreeNode treeNodeToOpen;

    // Open multi fix, 15/03/2021, EVGA -->
    List                treeNodelList = new List(Types::Class);
    ListEnumerator      le;
    // Open multi fix, 15/03/2021, EVGA -->

    while (aNode)    // only single....?!
    {
        treeNodeToOpen = this.usingTreeNode(aNode);

        if (treeNodeToOpen)
        {
            // Open multi fix, 15/03/2021, EVGA -->
            /*
                treeNodeToOpen.AOTnewWindow();
            */
            treeNodelList.addEnd(treeNodeToOpen);
            // Open multi fix, 15/03/2021, EVGA <--
        }

        aNode = _sysContextMenu.next();
    }

    // Open multi fix, 15/03/2021, EVGA -->
    le = treeNodelList.getEnumerator();

    while(le.moveNext())
    {
        treeNodeToOpen = le.current();

        if (treeNodeToOpen)
        {
            treeNodeToOpen.AOTnewWindow();
        }
    }
    // Open multi fix, 15/03/2021, EVGA <--
}
2. Создаем проект, добавляем туда таблицу
3. Выделяем все поля и из контекстного меню открываем всем EDT
Нажмите на изображение для увеличения
Название: 15.03.png
Просмотров: 62
Размер:	25.3 Кб
ID:	13140

4. Все открывшиеся EDT перетягиваем в свой проект и экспортируем.

* Как верно подметили, талица может ссылаться не только на EDT, а также на многое другое: другие таблицы, классы, enums, maps. Те, в свою очередь, могут аналогично ссылаться на что-то ещё. Поэтому задача рекурсивная. Если ее решить в лоб, то с большой степенью вероятности, на выходе вы получите почти все элементы слоя (модели), поэтому проще выгрузить весь слой.
Но на практики таких задач не возникает. Но иногда, что решается лишними +15..+30 минтуми времени. Т.е. волшебной кнопки не существует.
За это сообщение автора поблагодарили: trud (10).
Старый 15.03.2021, 12:42   #8  
v.i.p.to is offline
v.i.p.to
Участник
 
14 / 10 (1) +
Регистрация: 24.07.2015
Цитата:
Сообщение от Raven Melancholic Посмотреть сообщение
Сразу возникает вопрос не только про EDT.
  • Сами EDT могут расширять другие EDT, то есть нужно выгружать и родительские EDT (вплоть до самого базового).?
  • EDT может быть создано на основе BaseEnum (ну и поле может быть не на основе EDT, а BaseEnum), то есть нужны и BaseEnum?
  • На таблице могут быть relation и deleteaction на другие таблицы. Так как DAX2009, то на EDT могут быть relation на другие таблицы. Нужны ли эти таблицы? Если нужны, то нужны ли их EDT и далее по цепочке?
  • На EDT могут быть ссылки на lookup формы, их выгружать? А если в тех lokup формах есть другие таблицы, естественно, со своими свойствами, их выгружать?
  • На таблице могут быть заданы ссылки на формы и отчеты. Их выгружать? А если в тех формах и отчетах есть другие таблицы, естественно, со своими свойствами, их выгружать?
  • Ну и так далее, причем, с рекурсией.
В общем случае решения просто не существует или универсальное решение будет выгружать половину объектов AOT.
Спасибо, вот примерно это у меня и кружилось в голове что не все так просто...
Старый 15.03.2021, 12:44   #9  
v.i.p.to is offline
v.i.p.to
Участник
 
14 / 10 (1) +
Регистрация: 24.07.2015
Да Mazzy, ваши рекомендации отличные но
Проект изначально написан другими людьми которые не позаботились о том чтобы все собрать как проект и дать названия объектам соответствующее..
Старый 15.03.2021, 15:18   #10  
mazzy is offline
mazzy
Участник
Аватар для mazzy
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
29,472 / 4494 (208) ++++++++++
Регистрация: 29.11.2001
Адрес: Москва
Записей в блоге: 10
Цитата:
Сообщение от v.i.p.to Посмотреть сообщение
Да Mazzy, ваши рекомендации отличные но
Проект изначально написан другими людьми которые не позаботились о том чтобы все собрать как проект и дать названия объектам соответствующее..
Значит теперь это ваша задача. Как минимум собрать проект.
__________________
полезное на axForum, github, vk, coub.
Старый 16.03.2021, 10:14   #11  
v.i.p.to is offline
v.i.p.to
Участник
 
14 / 10 (1) +
Регистрация: 24.07.2015
Цитата:
Сообщение от DSPIC Посмотреть сообщение
1. Вносим правку в стандартный метод \Classes\SysOpenNewWindowApplObject\runsysContextMenu
X++:
void runsysContextMenu(SysContextMenu _sysContextMenu)
{
    TreeNode aNode = _sysContextMenu.first();
    TreeNode treeNodeToOpen;

    // Open multi fix, 15/03/2021, EVGA -->
    List                treeNodelList = new List(Types::Class);
    ListEnumerator      le;
    // Open multi fix, 15/03/2021, EVGA -->

    while (aNode)    // only single....?!
    {
        treeNodeToOpen = this.usingTreeNode(aNode);

        if (treeNodeToOpen)
        {
            // Open multi fix, 15/03/2021, EVGA -->
            /*
                treeNodeToOpen.AOTnewWindow();
            */
            treeNodelList.addEnd(treeNodeToOpen);
            // Open multi fix, 15/03/2021, EVGA <--
        }

        aNode = _sysContextMenu.next();
    }

    // Open multi fix, 15/03/2021, EVGA -->
    le = treeNodelList.getEnumerator();

    while(le.moveNext())
    {
        treeNodeToOpen = le.current();

        if (treeNodeToOpen)
        {
            treeNodeToOpen.AOTnewWindow();
        }
    }
    // Open multi fix, 15/03/2021, EVGA <--
}
2. Создаем проект, добавляем туда таблицу
3. Выделяем все поля и из контекстного меню открываем всем EDT
Вложение 13140

4. Все открывшиеся EDT перетягиваем в свой проект и экспортируем.

* Как верно подметили, талица может ссылаться не только на EDT, а также на многое другое: другие таблицы, классы, enums, maps. Те, в свою очередь, могут аналогично ссылаться на что-то ещё. Поэтому задача рекурсивная. Если ее решить в лоб, то с большой степенью вероятности, на выходе вы получите почти все элементы слоя (модели), поэтому проще выгрузить весь слой.
Но на практики таких задач не возникает. Но иногда, что решается лишними +15..+30 минтуми времени. Т.е. волшебной кнопки не существует.
Спасибо, тоже пригодилось.
Теги
axapta 2009, экспорт данных

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Не устанавливается свойство extendedDataType Yegor DAX: Программирование 15 29.05.2007 12:21
создать и передать временную таблицу kitty DAX: Программирование 11 13.07.2006 14:40
Невозможно создать таблицу chel DAX: Программирование 0 21.04.2004 21:02
Русская локализация Axapta 3 ? SlavaK DAX: Администрирование 59 01.07.2003 22:38
Можно ли в Аксапте экспортировать таблицу с находящимися в ней данными? Yuri Safronov DAX: Администрирование 2 28.08.2002 19:26
Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

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

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

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