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

 
 
Опции темы Поиск в этой теме Опции просмотра
Старый 25.11.2009, 16:19   #21  
propeller is offline
propeller
Участник
Аватар для propeller
 
359 / 29 (1) +++
Регистрация: 25.07.2007
X++:
    axaptaTable.ExecuteStmt("select * from %1 where %1.InvoiceDate == 24\11\2009");
Тоже самое через mkdate() вернуло записи.
Старый 25.11.2009, 16:28   #22  
Russland is offline
Russland
MCTS
Аватар для Russland
MCBMSS
 
267 / 116 (4) +++++
Регистрация: 17.10.2005
Адрес: Донеччина, Україна
Странно
X++:
CustInvoiceJour.ExecuteStmt(
"select firstonly %1 where %1.DueDate == 24\10\2005");
сработало. Возможно в вашем случае надо было Found"ом установиться на первую запись.

Ну да ладно
можно воспользоваться date2StrXpp() класса Global которая проконвертит дату в string

X++:
	ax.CallStaticClassMethod("Global", "date2StrXpp", myDate );
__________________

В глухомани, в лесу Несмотря на красу Дни проводит Лиса Патрикевна. Я никак не пойму Отчего, почему Не пускают куму На деревню

Последний раз редактировалось Russland; 25.11.2009 в 16:32.
Старый 25.11.2009, 19:04   #23  
Владимир Максимов is offline
Владимир Максимов
Участник
КОРУС Консалтинг
 
1,691 / 1195 (43) ++++++++
Регистрация: 13.01.2004
Записей в блоге: 3
Цитата:
Сообщение от propeller Посмотреть сообщение
X++:
    axaptaTable.ExecuteStmt("select * from %1 where %1.InvoiceDate == 24\11\2009");
Тоже самое через mkdate() вернуло записи.
Хм... А дальше? Я почему спрашиваю? Обычно в подобных тестах кроме замены значения еще что-то дописывают/удаляют. Вот мне и интересно, не получилось ли так, что при использовании mkdate() что-то еще было дописано/удалено? Или наоборот, при использовании литерала (константы) что-то еще сделали? Может axaptaTable создан не по той таблице, где есть поле InvoiceDate?

Можете привести полный код теста? Т.е. с момента создания Com-объекта и проверки того факта, что запрос что-то вернул или не вернул?

Ну, в порядке бреда, можно попробовать поиграться порядком расположения года, месяца и дня. Хотя формат литерала и жестко прописан, но, может какие-то настройки есть?
Старый 26.11.2009, 10:08   #24  
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   #25  
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   #26  
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   #27  
Russland is offline
Russland
MCTS
Аватар для Russland
MCBMSS
 
267 / 116 (4) +++++
Регистрация: 17.10.2005
Адрес: Донеччина, Україна
а запись в таблице за 24 ноября есть?
__________________

В глухомани, в лесу Несмотря на красу Дни проводит Лиса Патрикевна. Я никак не пойму Отчего, почему Не пускают куму На деревню
Старый 26.11.2009, 14:11   #28  
propeller is offline
propeller
Участник
Аватар для propeller
 
359 / 29 (1) +++
Регистрация: 25.07.2007
Цитата:
Сообщение от Russland Посмотреть сообщение
а запись в таблице за 24 ноября есть?
конечно, есть. если просто подписать mkdate, сразу все работает. Не знаю может быть это такая версия коннектора, или из за того что это Ax 2.5
Старый 26.11.2009, 15:05   #29  
Владимир Максимов is offline
Владимир Максимов
Участник
КОРУС Консалтинг
 
1,691 / 1195 (43) ++++++++
Регистрация: 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, время: 08:13.