Цитата:
Сообщение от
user_ax
В теле отчёта делаю
X++:
queryRun = this.main_query();
while(queryRun.next())
{
vendsp = queryRun.get(tablenum(VendSpListJour));
vendsplist = queryRun.get(tablenum(VendSpListTrans));
vendinvoice = queryRun.get(tablenum(VendInvoiceTrans));
Если вы это имели ввиду.
А зачем так много таблиц, ведь данные, если я не ошибаюсь будут только в VendInvoiceTrans. Для того что бы получить значения полей из других таблиц их надо тоже включать в группировку. Вот пример как получить значение закупки из другой таблицы, если группировку не делать то она будет пустой.
X++:
void main_query(boolean _count_query = false)
{
VendInvoiceJour VendInvoiceJour;
VendInvoiceTrans VendInvoiceTrans;
QueryRun QueryRun;
Query query = new Query();
QueryBuildDataSource qbds;
QueryBuildRange qbr;
;
qbds = query.addDataSource(tablenum(VendInvoiceJour));
qbds.addSortField(fieldnum(VendInvoiceJour,purchId));
qbds.addSelectionField(fieldnum(VendInvoiceJour,Qty), SelectionField::Sum);
qbds.orderMode(OrderMode::GroupBy);
qbds.addRange(fieldnum(VendInvoiceJour,purchId)).value('Номер закупки');
qbds = qbds.addDataSource(tablenum(VendInvoiceTrans));
qbds.addSortField(fieldnum(VendInvoiceTrans,purchId));
qbds.orderMode(OrderMode::GroupBy);
qbds.addLink(fieldnum(VendInvoiceJour,purchId),fieldnum(VendInvoiceTrans,purchId));
QueryRun = new QueryRun(query);
while (queryRun.next())
{
VendInvoiceJour = QueryRun.get(tablenum(VendInvoiceJour));
VendInvoiceTrans = QueryRun.get(tablenum(VendInvoiceTrans));
info(strFmt("%1 %2",VendInvoiceJour.PurchId,VendInvoiceJour.Qty));
info(strFmt("%1",VendInvoiceTrans.PurchId));
}
}