Following Job illustrates how we can get the criteria / ranges specified by the user in the run-time Query criteria dialog.
QueryRun queryRun;
QueryBuildDataSource qbd;
CustTable custTable;
QueryBuildRange range;
int cnt, i;
;
qbd = query.addDataSource(tablenum(CustTable));
queryRun = new QueryRun(query);
queryRun.prompt(); // To Prompt the dialog
cnt = queryRun.query().dataSourceTable(tablenum(CustTable)).rangeCount();
for (i=1 ; i<=cnt; i++)
{
range = queryRun.query().dataSourceTable(tablenum(CustTable)).range(i);
info(strfmt("Range Field %1, Value %2",range.AOTname(),range.value()));
}
while (queryRun.next())
{
custTable = queryRun.get(tablenum(CustTable));
info(strfmt("Customer %1, Name %2",custTable.AccountNum, custTable.Name));
}
}
static void Query_getRanges(Args _args)
{
Query query = new Query();QueryRun queryRun;
QueryBuildDataSource qbd;
CustTable custTable;
QueryBuildRange range;
int cnt, i;
;
qbd = query.addDataSource(tablenum(CustTable));
queryRun = new QueryRun(query);
queryRun.prompt(); // To Prompt the dialog
cnt = queryRun.query().dataSourceTable(tablenum(CustTable)).rangeCount();
for (i=1 ; i<=cnt; i++)
{
range = queryRun.query().dataSourceTable(tablenum(CustTable)).range(i);
info(strfmt("Range Field %1, Value %2",range.AOTname(),range.value()));
}
while (queryRun.next())
{
custTable = queryRun.get(tablenum(CustTable));
info(strfmt("Customer %1, Name %2",custTable.AccountNum, custTable.Name));
}
}
No comments:
Post a Comment
Note: Only a member of this blog may post a comment.