Skip to main content

Dynamics AX2009 – Useful utility “SysQueryRangeUtil”

In AX 2009 there is utility through whihc we can provide arguments/ placeholders for field values in Select query whicle processing reports or filtering data in an inquiry form.

There are following functions for use in AX2009 in Select query as an argument for field values..

e.g. to use the current employee’s ID as an argument use the following in the “Employee” field in Select query filter. In the following screenshot we are trying to fetch the Project Journals posted by the employee ID attached the current user so that user can see their own journals only.



class SysQueryRangeUtil

Run On :Called

Methods

Method Description

cancelTimeOut Cancels a previous method call to the Object::setTimeOut Method. (Inherited from Object.)

equal Determines whether the specified object is equal to the current one. (Inherited from Object.)

getTimeOutTimerHandle Returns the timer handle for the object. (Inherited from Object.)

handle Retrieves the handle of the class of the object. (Inherited from Object.)

new Initializes a new instance of the Object class.. (Inherited from Object.)

notify Releases the hold on an object that has called a wait method on this object. (Inherited from Object.)

notifyAll Releases a lock on the object that was issued by a wait method on this object. (Inherited from Object.)

objectOnServer Determines whether the object is on a server. (Inherited from Object.)

owner Returns the instance that owns the object. (Inherited from Object.)

setTimeOut Sets up the scheduled execution of a specified method. (Inherited from Object.)

toString Returns a string that represents the current object. (Inherited from Object.)

usageCount Returns the current number of references (the value of the reference counter) that the object has. (Inherited from Object.)

wait Pauses a process. (Inherited from Object.)

xml Returns an XML string that represents the current object. (Inherited from Object.)

The following arguments are very useful and easy to understand for consultants

::currentBusinessRelationsAccount

::currentContactPersonId

::currentCustomerAccount

::currentEmployeeId

::currentSessionDate

::currentSessionDateTime

::currentStaticMasterPlan

::currentUserId

::currentVendorAccount

::dateRange

::day

::dayRange

::greaterThanDate

::lessThanDate

::monthRange

::yearRange

These arguments may play a useful roles when configuring a periodic batches for cleanups e.g. Deleting the Invoiced orders and moving them to voided order table..

Popular posts from this blog

Dynamics Axapta: Sales Orders & Business Connector

Well, again folllowing my same idea of writting close to nothing and pasting code, I'll paste in some code to create a sales order from some basic data and the invoice it. I'll try to explain more in the future. AxaptaObject axSalesTable = ax.CreateAxaptaObject("AxSalesTable"); AxaptaRecord rcInventDim = ax.CreateAxaptaRecord("InventDim"); AxaptaRecord rcCustTable = ax.CreateAxaptaRecord("CustTable"); rcCustTable.ExecuteStmt("select * from %1 where %1.AccountNum == '" + MySalesOrderObject.CustAccount + "'"); if (MySalesOrderObject.CurrencyCode.Trim().Length == 0) MySalesOrderObject.CurrencyCode = rcCustTable.get_Field("Currency").ToString().Trim(); string sTaxGroup = rcCustTable.get_Field("taxgroup").ToString().Trim(); //set header level fields axSalesTable.Call("parmSalesName", MySalesOrderObject.SalesName.Trim()); axSalesTable.Call("parmCustAccount", M

Passing values between form and class

Class name is EmplDuplication and Form is EmplTable . void clicked() {    MenuFunction mf;    args args = new Args();    ;     args.record(EmplTable);     mf = new menufunction(identifierstr(EmplDuplication), MenuItemType::Action); mf.run(args); } Meanwhile, in the main() method of the EmplDuplication class, we need to put this Axapta x++ code to get the datasource: static void main(Args args) {     EmplDuplication EmplDuplication; EmplTable localEmplTable; ;     if(args.record().TableId == tablenum(EmplTable)) localEmplTable = args.record();     ... }