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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 11.09.2010, 17:00   #1  
sukhanchik is offline
sukhanchik
Administrator
Аватар для sukhanchik
MCBMSS
Злыдни
Лучший по профессии 2015
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,326 / 3556 (125) ++++++++++
Регистрация: 13.06.2004
Адрес: Москва
DAX 2009 RU5 - Ошибка компилятора в конструкции select
Всем привет!
Наткнулся тут на интересную ошибку компилятора.
X++:
static void Job1(Args _args)
{
    DocuRef docuRef;
    CustTable custTable;
    ;
    select docuRef
        where docuRef.RefTableId == tablenum(CustTable)
        join custTable // Ошибка компиляции на этой строке
            where custTable.RecId == docuRef.RefRecId;
}
Что интересно, что ошибка проявляется исключительно на такой конструкции. Т.е. не воспринимается использование функции tablenum непосредственно перед оператором join.
Т.е. добавление между tablenum и join еще одного условия, например, написание так:
X++:
where docuRef.RefTableId == tablenum(CustTable) && true
перенос условия с tablenum после join, замена tablenum на custTable.TableId - все прокатывает.
Но в 2009 RU5 компилятор пишет "Синтаксическая ошибка", а в 4.0 SP2 - "Переменная join не объявлена"
__________________
Возможно сделать все. Вопрос времени
За это сообщение автора поблагодарили: gl00mie (2).
Старый 12.09.2010, 12:44   #2  
Волчара is offline
Волчара
Участник
 
210 / 29 (1) +++
Регистрация: 08.02.2003
Адрес: Москва
Поменяй одну строчку
X++:
        where docuRef.RefTableId == custTable.TableId
Получится конструкция не совсем корректная в смысле SQL но вполне корректная с точки зрения Axapta т.к. custTable.TableId - это константа...
__________________
Благодарю за поддержку ИЦ Кариатиду и Koder Logic

Последний раз редактировалось Волчара; 12.09.2010 в 12:47. Причина: объяснение причины некорректности
Старый 12.09.2010, 13:19   #3  
sukhanchik is offline
sukhanchik
Administrator
Аватар для sukhanchik
MCBMSS
Злыдни
Лучший по профессии 2015
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,326 / 3556 (125) ++++++++++
Регистрация: 13.06.2004
Адрес: Москва
Цитата:
Сообщение от Волчара Посмотреть сообщение
Поменяй одну строчку
X++:
        where docuRef.RefTableId == custTable.TableId
Я ж изначально сказал что это прокатывает.
Цитата:
Сообщение от sukhanchik Посмотреть сообщение
перенос условия с tablenum после join, замена tablenum на custTable.TableId - все прокатывает.
Дело-то не в том, как это обойти - а в том, что это достаточно неожиданная ошибка
__________________
Возможно сделать все. Вопрос времени
Старый 13.09.2010, 11:51   #4  
samolalex is offline
samolalex
Участник
Аватар для samolalex
Самостоятельные клиенты AX
 
259 / 107 (4) +++++
Регистрация: 18.06.2010
Адрес: Москва
В Axapta 3.0 SP1 компилятор так же пишет о синтаксической ошибке после tablenum(CustTable). Поэтому я могу сделать вывод о том, что в 5 версии разработчики решили вернуться к прежним обобщенным спецификациям ошибок, а именно "Синтаксическая ошибка"
__________________
С уважением, Александр.
Старый 13.09.2010, 12:00   #5  
sukhanchik is offline
sukhanchik
Administrator
Аватар для sukhanchik
MCBMSS
Злыдни
Лучший по профессии 2015
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,326 / 3556 (125) ++++++++++
Регистрация: 13.06.2004
Адрес: Москва
__________________
Возможно сделать все. Вопрос времени
Старый 14.09.2010, 01:56   #6  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Проблема с компиляцией такого выражения известна.
Сам текст ошибки - пофиг имхо, Синтаксическая ошибка получше будет.

Лечится просто - нужно объявить переменную, ей присвоить это значение, и переменную уже использовать в select statement.
Старый 14.09.2010, 02:03   #7  
Logger is offline
Logger
Участник
Лучший по профессии 2015
Лучший по профессии 2014
 
3,953 / 3230 (115) ++++++++++
Регистрация: 12.10.2004
Адрес: Москва
Записей в блоге: 2
Цитата:
Сообщение от kashperuk Посмотреть сообщение
Проблема с компиляцией такого выражения известна.
Сам текст ошибки - пофиг имхо, Синтаксическая ошибка получше будет.

Лечится просто - нужно объявить переменную, ей присвоить это значение, и переменную уже использовать в select statement.
Т.е. это фича, а не баг ? Исправлять не будут ?
Старый 14.09.2010, 11:28   #8  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Цитата:
Сообщение от Logger Посмотреть сообщение
Т.е. это фича, а не баг ? Исправлять не будут ?
Нет, это баг, конечно же.
Но исправлять пока/вообще не будут.

К счастью, есть простой workaround
За это сообщение автора поблагодарили: mazzy (2).
Старый 17.08.2011, 14:40   #9  
gl00mie is offline
gl00mie
Участник
MCBMSS
Most Valuable Professional
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии AXAWARD 2013
Лучший по профессии 2011
Лучший по профессии 2009
 
3,684 / 5798 (201) ++++++++++
Регистрация: 28.11.2005
Адрес: Москва
Записей в блоге: 3
Случайно наткнулся на свидетельство того, что разработчики стандартного приложения про этот косяк давно знают и нашли свой workaround без использования промежуточных переменных - см., например, \Classes\DirPartyMerge\runOnServer:
X++:
while select forupdate docuRef
    where docuRef.RefTableId == (tablenum(DirPartyTable))
    join partyTable
    where partyTable.PartyId == dirPartyId &&
          partyTable.RecId == docuRef.RefRecId
Т.е., оказывается, достаточно заключить tablenum в круглые скобки
За это сообщение автора поблагодарили: AlGol (2), sukhanchik (2), MikeR (5), S.Kuskov (3).
Старый 11.01.2013, 08:43   #10  
S.Kuskov is offline
S.Kuskov
Участник
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
 
3,440 / 1775 (66) ++++++++
Регистрация: 28.04.2007
Адрес: Калуга
В очердной раз наткнулся на этот баг. Ошибка воспроизводится не только с функцией tablenum, но и со всеми встроенными функциями из AOT\System Documentation\Functions
Теги
баг, ошибка

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
DAX 2009 RU5. Ответственное хранение. Lz_ DAX: Функционал 18 19.07.2010 12:17
Ошибка при установке аоса DAX 2009 Rect DAX: Администрирование 2 14.07.2010 18:27
DAX 2009 InventSum Кнопка запрос - ошибка f18 DAX: Программирование 0 09.04.2010 14:51
emeadaxsupport: List of fixes that improve performance of certain features in Dynamics AX 2009 Blog bot DAX Blogs 0 13.10.2009 19:06
Русская локализация Axapta 3 ? SlavaK DAX: Администрирование 59 01.07.2003 22:38
Опции темы Поиск в этой теме
Поиск в этой теме:

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

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

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

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