Reporting tools, such as Jasper Report and
BIRT, don’t have enough support for multi-datasources,
leading to complicated Java program for realizing dynamic datasources. But by
using esProc to assist the reporting tool, this won’t be a problem anymore. The
following example will teach you how esProc works to realize the dynamic
datasources.
myDB1 and myDB2 are different
databases, but both have a table sales
holding different data. We want to control the source of data of the report
through the parameter PsCode and the
range of data retrieval through the other two parameters – Pbegin and Pend.
esProc code for doing this:
As you
can see, esProc just uses a line of code to achieve using datasources
dynamically.
sCode, begin and end are all esProc parameters. They can be set in the following window:
begin and end are used to define the range of
retrieving data from SQL and sCode is
used to switch between datasources . The macro ${sCode} is to parse the
parameters to get an esProc expression. To assign myDB2 to sCode, for instance,
the above esProc script will be parsed into result myDB2.query("select
* from sales where OrderDate>=? and OrderDate <=?",begin,end).
query function is used to
execute an SQL statement, and receives parameters passed to it.
result statement will return the result to the reporting tool.
esProc provides JDBC interface to be
integrated with the reporting tool, which will identify esProc as a database.
For detailed integration solution, please refer to related documents
Define three parameters – PsCode, Pbegin and Pend – in the report to correspond to the three esProc parameters. Click on Preview to see the completed report:
In the above report, PsCode’s value is myDB1. We can change the value to myDB2 to see the effect of having dynamic datasources:
Notice that the way a report calls the
esProc script is the same as that it calls the stored procedure. If we save the
script as dsource.dfx, then it can be
called by dsource $P{PsCode},$P{Pbegin},$P{Pend} in Jasper Report’s SQL designer.
This esProc script uses connect and close function to connect to or close the database explicitly,
which features a higher flexibility.
No comments:
Post a Comment