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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 26.11.2009, 10:08   #1  
propeller is offline
propeller
Участник
Аватар для propeller
 
359 / 29 (1) +++
Регистрация: 25.07.2007
X++:
  Axapta = new Com("AxaptaCOMConnector.axapta2");
    Axapta.Logon2(****);
    transdate = mkdate(25,11,2009);
 
    axaptaTable = Axapta.CreateRecord("CustInvoiceJour");
    axaptaTable.ExecuteStmt("select * from %1 where %1.InvoiceDate == 24\11\09");

    while (axaptaTable.found())
    {
        axaptafield = axaptaTable.field("InvoiceId");
        info(axaptafield.bStr());
        axaptaTable.next();
    }
Job запускаю в Ax 4.0, комконнектор коннектится к Ax 2.5
Старый 26.11.2009, 11:07   #2  
kashperuk is offline
kashperuk
Участник
Аватар для kashperuk
MCBMSS
Соотечественники
Сотрудники Microsoft Dynamics
Лучший по профессии 2017
Лучший по профессии 2015
Лучший по профессии 2014
Лучший по профессии 2011
Лучший по профессии 2009
 
4,361 / 2084 (78) +++++++++
Регистрация: 30.05.2004
Адрес: Atlanta, GA, USA
Цитата:
Сообщение от propeller Посмотреть сообщение
X++:
  Axapta = new Com("AxaptaCOMConnector.axapta2");
    Axapta.Logon2(****);
    transdate = mkdate(25,11,2009);
 
    axaptaTable = Axapta.CreateRecord("CustInvoiceJour");
    axaptaTable.ExecuteStmt("select * from %1 where %1.InvoiceDate == 24\11\09");

    while (axaptaTable.found())
    {
        axaptafield = axaptaTable.field("InvoiceId");
        info(axaptafield.bStr());
        axaptaTable.next();
    }
Job запускаю в Ax 4.0, комконнектор коннектится к Ax 2.5
Это вы сейчас сократили 2009 до 09 в дате или так и пробуете запускать?
Старый 26.11.2009, 12:42   #3  
propeller is offline
propeller
Участник
Аватар для propeller
 
359 / 29 (1) +++
Регистрация: 25.07.2007
axaptaTable.ExecuteStmt("select * from %1 where %1.InvoiceDate == 24\11\2009");
пробовал и так и так. ничего не изменилось.
Старый 26.11.2009, 12:53   #4  
Russland is offline
Russland
MCTS
Аватар для Russland
MCBMSS
 
267 / 116 (4) +++++
Регистрация: 17.10.2005
Адрес: Донеччина, Україна
а запись в таблице за 24 ноября есть?
__________________

В глухомани, в лесу Несмотря на красу Дни проводит Лиса Патрикевна. Я никак не пойму Отчего, почему Не пускают куму На деревню
Старый 26.11.2009, 14:11   #5  
propeller is offline
propeller
Участник
Аватар для propeller
 
359 / 29 (1) +++
Регистрация: 25.07.2007
Цитата:
Сообщение от Russland Посмотреть сообщение
а запись в таблице за 24 ноября есть?
конечно, есть. если просто подписать mkdate, сразу все работает. Не знаю может быть это такая версия коннектора, или из за того что это Ax 2.5
Старый 26.11.2009, 15:05   #6  
Владимир Максимов is offline
Владимир Максимов
Участник
КОРУС Консалтинг
 
1,718 / 1204 (44) ++++++++
Регистрация: 13.01.2004
Записей в блоге: 3
Цитата:
Сообщение от propeller Посмотреть сообщение
X++:
  Axapta = new Com("AxaptaCOMConnector.axapta2");
    Axapta.Logon2(****);
    transdate = mkdate(25,11,2009);
 
    axaptaTable = Axapta.CreateRecord("CustInvoiceJour");
    axaptaTable.ExecuteStmt("select * from %1 where %1.InvoiceDate == 24\11\09");

    while (axaptaTable.found())
    {
        axaptafield = axaptaTable.field("InvoiceId");
        info(axaptafield.bStr());
        axaptaTable.next();
    }
Job запускаю в Ax 4.0, комконнектор коннектится к Ax 2.5
Это так и задумано, что mkDate() - на 25 число, а запрос с константой - на 24? Если попоробовать подставить ДРУГИЕ даты в виде константы?

И еще, поле CustInvoiceJour.InvoiceId не имеет признака Mandatory. Вы уверены, что для найденных записей InvoiceId указано? Может, пытаться читать RecId? Или просто подсчитывать количество шагов цикла (количество строк в выборке).

Вот такой тест что даст

X++:
    Axapta = new Com("AxaptaCOMConnector.axapta2");
    Axapta.Logon2(****);
    transdate = mkdate(1,11,2009);
 
    for (nextI = 1; nextI <= 30; nextI++ )
    {
        axaptaTable = Axapta.CreateRecord("CustInvoiceJour");
        axaptaTable.ExecuteStmt("select * from %1 where %1.InvoiceDate == " + global::date2StrXpp(transdate));
        
        if (axaptaTable.found()) info(strFmt("%1 YES", transDate));
        else info(strFmt("%1 NO", transDate));

        transdate += 1;
    }
Теги
com connector

 

Похожие темы
Тема Автор Раздел Ответов Посл. сообщение
Проблемы с AxaptaCOMConnector Old DAX: Программирование 1 26.07.2007 10:34
Вопрос по Проектам PSA DAX: Функционал 35 19.01.2007 22:26
AxaptaCOMConnector Yari DAX: Программирование 3 14.04.2006 15:25
AxaptaComConnector для новичка murad DAX: Программирование 8 05.10.2005 15:30
Вопрос по AxaptaCOMConnector sk45 DAX: Программирование 5 10.09.2004 16:16

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

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

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