|
![]() |
#1 |
Боец
|
Мы сделали так. Скорость разноски увеличилась на порядок.
1. Обявляем в классе \Classes\Application.classDeclaration переменную X++: Map mappingsInfo_RU; // Оптимизация разноски накладной, EVO 26.04.2011 X++: // Оптимизация разноски накладной, EVO 26.04.2011 Map mappingsInfo_RU() { ; if (!mappingsInfo_RU) { mappingsInfo_RU = new Map(Types::Container, Types::Class); // [TableId, MapId], MappingsInfo_RU object } return mappingsInfo_RU; } X++: static public Map createMapWithFieldId(tableId _tableId, tableId _mapID) { MappingsInfo_RU mappingsInfo; ; // Оптимизация разноски накладной, EVO 26.04.2011 --> //orig mappingsInfo = new MappingsInfo_RU(_tableId, _mapID); //orig return mappingsInfo.find(); if (!appl.mappingsInfo_RU().exists([_tableId, _mapID])) { mappingsInfo = new MappingsInfo_RU(_tableId, _mapID); appl.mappingsInfo_RU().insert([_tableId, _mapID], mappingsInfo.find()); } return appl.mappingsInfo_RU().lookup([_tableId, _mapID]); // Оптимизация разноски накладной, EVO 26.04.2011 <-- } Последний раз редактировалось DSPIC; 09.06.2011 в 23:23. |
|
|
За это сообщение автора поблагодарили: UNRW (1), wolfstein (1). |
![]() |
#2 |
Administrator
|
Идиотский вопрос: А зачем новый метод в классе Application? Почему не использовать appl.globalcache() ? Там такой же Map.
__________________
Возможно сделать все. Вопрос времени |
|
|
За это сообщение автора поблагодарили: DSPIC (5). |
![]() |
#3 |
Axapta Retail User
|
С использованием appl.globalcache() - модифицируем метод \Classes\MappingsInfo_RU\createMapWithFieldId следующим образом:
X++: static public Map createMapWithFieldId(tableId _tableId, tableId _mapID) { MappingsInfo_RU mappingsInfo; ; //mappingsInfo = new MappingsInfo_RU(_tableId, _mapID); //return mappingsInfo.find(); if (!appl.globalCache().isSet(classstr(MappingsInfo_RU), [_tableId, _mapID])) { mappingsInfo = new MappingsInfo_RU(_tableId, _mapID); appl.globalCache().set(classstr(MappingsInfo_RU), [_tableId, _mapID], mappingsInfo.find()); } return appl.globalCache().get(classstr(MappingsInfo_RU), [_tableId, _mapID]); } |
|
|
За это сообщение автора поблагодарили: DSPIC (5). |
Теги |
bug, map, treenode, баг, локализация, накладная, налоги, ошибка, счет-фактура |
|
Опции темы | Поиск в этой теме |
Опции просмотра | |
|