|
23.09.2010, 12:16 | #1 |
Участник
|
можно ли в Аксапте сделать такой Query
можно ли в Аксапте сделать такой Query?
Для заданного Поставщика находить Закупки со статусом «открыто», у которых либо нет строк с определённой номенклатурой, либо есть неблокированные строки с этой номенклатурой и все они находятся в статусе «открыто» по условию query минимальный для выборки данных во временную таблицу но нельзя делать вложенные while select { while select { после анализа я кажется попробовал перефразировать условие в результате получилось Для заданного Поставщика находить Закупки со статусом «открыто», у которых не должны попадаться закупки где в строках есть указанная номенклатура и статус строк не открыто или строки заблокированы и при этом как то надо умудриться получить sum(количества) из purchline чтобы там где нет строк было бы 0 |
|
23.09.2010, 12:29 | #2 |
Участник
|
в AX2009 можно попробовать решить, используя Union. В предыдущих версиях, если без while, то можно за два последовательных запроса.
|
|
23.09.2010, 12:32 | #3 |
Участник
|
" либо нет строк с определённой номенклатурой, либо есть неблокированные строки с этой номенклатурой и все они находятся в статусе «открыто»"
=> нет строк, клоторая блокированна или закрыта? |
|
23.09.2010, 13:07 | #4 |
Участник
|
" либо нет строк с определённой номенклатурой, либо есть неблокированные строки с этой номенклатурой и все они находятся в статусе «открыто»"
=> нет строк, клоторая блокированна или закрыта? получается можно перефразировать как получить сумма количества в строках закупок для данной номенклатуры для всех открытых закупок для данного поставщика, кроме тех закупок где есть хотя бы одна закрытая или заблокированная строка с данной номенклатурой. по идее будет тот же набор записей только через другой запрос. первый вариант как я понял мжно сделать при помощи union но в 4-ке и тройке такого типа вроде нет. вообщем попробую |
|
23.09.2010, 13:30 | #5 |
Участник
|
X++: static void PurchLineQuery(Args _args) { QueryBuildDataSource qbdsPurchLineSum,qbdsPurchTable,qbds; QueryBuildRange qbr; Query q = new Query(); QueryRun qr; PurchLine PurchLine; #define.itemIdParm('123') ; qbdsPurchLineSum = q.addDataSource(tableNum(PurchLine)); qbdsPurchLineSum.addSelectionField(fieldNum(PurchLine,PurchQty),SelectionField::Sum);//внимание на единицы измерения! может даже лучше идти по inventTrans qbr = sysQuery::findOrCreateRange(qbdsPurchLineSum,fieldNum(PurchLine,PurchStatus)); qbr.value(queryValue(PurchStatus::Backorder)); qbr = sysQuery::findOrCreateRange(qbdsPurchLineSum,fieldNum(PurchLine,ItemId)); qbr.value(queryValue(#itemIdParm)); qbdsPurchTable = qbdsPurchLineSum.addDataSource(tableNum(PurchTable)); qbdsPurchTable.joinMode(joinMode::ExistsJoin); qbdsPurchTable.fetchMode(QueryFetchMode::One2One); qbdsPurchTable.relations(true); qbr = sysQuery::findOrCreateRange(qbdsPurchTable,fieldNum(PurchTable,PurchStatus)); qbr.value(queryValue(PurchStatus::Backorder)); qbds = qbdsPurchTable.addDataSource(tableNum(PurchLine)); qbds.joinMode(joinMode::NoExistsJoin); qbds.fetchMode(QueryFetchMode::One2One); qbds.relations(true); qbr = sysQuery::findOrCreateRange(qbds,fieldNum(PurchLine,ItemId)); qbr.value(queryValue(#itemIdParm)); qbr = sysQuery::findOrCreateRange(qbds,fieldNum(PurchLine,RecId)); qbr.value(strFmt('((%1.%2 != "%3") || (%4.%5 == "%5"))', qbds.name(), fieldId2name(tableNum(PurchLine),fieldNum(PurchLine,PurchStatus)), queryValue(PurchStatus::Backorder), qbds.name(), fieldId2name(tableNum(PurchLine),fieldNum(PurchLine,Blocked)), queryValue(NoYes::Yes) ) ) ; info(qbdsPurchLineSum.toString()); qr = new QueryRun(q); while (qr.next()) { PurchLine = qr.get(PurchLine.TableId); info(strFmt("%1 %2",PurchLine.PurchId,PurchLine.PurchQty)); } } |
|
|
За это сообщение автора поблагодарили: Evgeniy2020 (2), jeky (2). |
23.09.2010, 14:54 | #6 |
Участник
|
2 Titiov:
спасибо подход правильный, только немного не правильный получается запрос и естественно ничего не возвращает, хотя запись есть. это из за того что получается вот такой запрос PurchLine PurchLine; PurchLine PurchLine_1_1; PurchTable PurchTable; ; while SELECT SUM(PurchQty) FROM PurchLine WHERE ((PurchLine.PurchStatus == 1)) && ((PurchLine.ItemId == 'ФТ-018')) EXISTS JOIN * FROM PurchTable WHERE PurchLine.PurchId == PurchTable.PurchId && ((PurchTable.PurchStatus == 1)) NOTEXISTS JOIN * FROM PurchLine WHERE PurchTable.PurchId == PurchLine.PurchId && ((PurchLine.ItemId == 'ФТ-018')) && ((((PurchLine_1_1.PurchStatus != 1) || (PurchLine_1_1.Blocked == 1)))) { info('1'); } если ручками потредактировать то вот такой запрос возвращает данные PurchLine PurchLine; PurchLine PurchLine_1_1; PurchTable PurchTable; ; while SELECT SUM(PurchQty) FROM PurchLine WHERE ((PurchLine.PurchStatus == 1)) && ((PurchLine.ItemId == 'ФТ-018')) EXISTS JOIN * FROM PurchTable WHERE PurchLine.PurchId == PurchTable.PurchId && ((PurchTable.PurchStatus == 1)) NOTEXISTS JOIN * FROM PurchLine_1_1 WHERE PurchTable.PurchId == PurchLine_1_1.PurchId && ((PurchLine_1_1.ItemId == 'ФТ-018')) && ((((PurchLine_1_1.PurchStatus != 1) || (PurchLine_1_1.Blocked == 1)))) { info('1'); } а как эти изменения внести в код Query который указан выше (предыдущий пост) ? |
|
23.09.2010, 15:42 | #7 |
Участник
|
Цитата:
стандартно не знаю способа, да и нет кажется но есть один "хитрый" путь создать вьюху PurchLineView1 с полями PurchId, PurchStatus, Blocked, RecId1, ItemId и в моем джобе сделать так PHP код:
|
|
23.09.2010, 16:15 | #8 |
Участник
|
Цитата:
Сообщение от Evgeniy2020
PurchLine PurchLine;
PurchLine PurchLine_1_1; PurchTable PurchTable; ; while SELECT SUM(PurchQty) FROM PurchLine WHERE ((PurchLine.PurchStatus == 1)) && ((PurchLine.ItemId == 'ФТ-018')) EXISTS JOIN * FROM PurchTable WHERE PurchLine.PurchId == PurchTable.PurchId && ((PurchTable.PurchStatus == 1)) NOTEXISTS JOIN * FROM PurchLine_1_1 WHERE PurchTable.PurchId == PurchLine_1_1.PurchId && ((PurchLine_1_1.ItemId == 'ФТ-018')) && ((((PurchLine_1_1.PurchStatus != 1) || (PurchLine_1_1.Blocked == 1)))) { info('1'); } X++: PurchLine PurchLine; PurchLine PurchLine_1_1; ; while select sum(PurchQty) from PurchLine where PurchLine.PurchStatus == 1 && PurchLine.ItemId == 'ФТ-018' notexists join PurchLine_1_1 where PurchLine_1_1.PurchId == PurchLine.PurchId && PurchLine_1_1.ItemId == PurchLine.ItemId && (PurchLine_1_1.PurchStatus != 1 || PurchLine_1_1.Blocked == 1) { info('1'); } |
|
|
За это сообщение автора поблагодарили: titov (2). |
25.09.2010, 14:02 | #9 |
Участник
|
Больно навороченный запрос получается - тормозить может...
|
|