|
![]() |
#1 |
Участник
|
|
|
![]() |
#2 |
newborn in DAX
|
почему && и || ?это же запрос который идёт на SQL сервер. Там вроде как and и or надо.
и слэши обратные как -то не очень. SQL сервер ругается на такое "Incorrect syntax near '\01'." не нравится ему дата в таком виде |
|
![]() |
#3 |
Участник
|
Неа. Это запрос, который ещё будет постобработан аксаптой.
Вот такой код у меня выполняется без ошибок: X++: static void JobTestExpressionsInQueryRanges(Args _args) { InventTrans InventTrans; fromDate fromDate = 03\05\2011; toDate toDate = 04\05\2011; Query q; QueryBuildDataSource qbdsInventTrans; QueryRun qr; ; q = new Query(); qbdsInventTrans = q.addDataSource(tableNum(InventTrans)); qbdsInventTrans.addRange(fieldNum(InventTrans, RecId)).value( strfmt("(((%1.%2 >= %4) && (%1.%2 <= %5)) || ((%1.%3 >= %4) && (%1.%3 <= %5)))" , qbdsInventTrans.name(), fieldStr(InventTrans, DatePhysical), fieldStr(InventTrans, DateFinancial), Date2StrXpp(fromDate), Date2StrXpp(toDate) )); info(qbdsInventTrans.toString()); qr = new QueryRun(q); while (qr.next()) { InventTrans = qr.get(tableNum(InventTrans)); info(InventTrans.ItemId); break; } info("."); } Впрочем этот нюанс и многие другие описаны в статье по ссылке, которую я приводил выше Последний раз редактировалось S.Kuskov; 23.05.2011 в 09:43. |
|
![]() |
#4 |
newborn in DAX
|
исходная дата приходит из календаря на форме
обратные слэши это после date2strxpp и после info(this.query().dataSourceTable(tableNum(mlm_TemporaryLeaveReport)).toString());и если я правильно понимаю должно быть and а не && т.е обратные слеши идут на SQL,а там их явно не ждали |
|
![]() |
#5 |
Участник
|
Нет. Ещё раз повторю, на самом деле текст запроса, который вы видите после info(this.query().dataSourceTable(tableNum(mlm_TemporaryLeaveReport)).toString()) ещё НЕ является окончательным вариантом SQL запроса. Аксапта его ещё будет обрабатывать. Сама заменит && и || на AND и OR и сконвертирует формат даты.
|
|
|
За это сообщение автора поблагодарили: timaluhs (1). |
![]() |
#6 |
newborn in DAX
|
Спасибо за помощь. Заработало.
Я можно ещё вопросик? А как посчитать HeadCounter (сколько строк высветилось после запроса)? |
|
![]() |
#7 |
Участник
|
Цитата:
Вот тут почитайте Количество строк в Query |
|
Теги |
query, querybuildrange, range, фильтр |
|
|