BackPrevious Page Next PageNext

Stored Procedures

Adding stored procedures to a catalog

Editing parameter values

Updating stored procedures

Converting the data in stored procedures

A stored procedure is a compiled program, consisting of one or more statements and is saved into a database. The statement in a stored procedure can be an SQL statement or a control flow statement, such as an If-else statement or a Loop statement. A stored procedure is stored in the DBMS, so that it can be called locally or remotely. In addition, a stored procedure can return a value, single result set or multiple result sets. Currently, JReport supports stored procedures that return a single result set. If a stored procedure returns more than one result set, the first one will be used by JReport.

As a program, a stored procedure can take parameters. There are three types of parameters: IN, OUT and INOUT. The IN parameter lets you pass values to the procedure. The OUT parameter returns values to the caller. The INOUT parameter enables you to pass initial values to the procedure, and then returns the updated value to the caller.

A stored procedure itself can be used to create page reports directly, and in this sense it functions the same as a query. Therefore, you can use the Data Manager to control the data retrieval of stored procedures and create cached result files for stored procedures the same as you do for queries. Stored procedures can also be used to build queries and business views.

Adding stored procedures to a catalog

To add procedures stored in the database to a catalog via a JDBC conn ection, take the following steps:

  1. In the Catalog Manager resource tree, right-click the JDBC connection node and click Add Stored Procedure on the shortcut menu. The Add Stored Procedures dialog appears.

    Add Stored Procedures dialog

  2. The dialog lists all the stored procedures in the Stored Procedures box in a three-level tree. The top level is SQL-catalog, the second is SQL-schema and the last level is stored procedures. Select the required stored procedures, and then click Add. However, not all DBMSs support database stored procedures. In this case, you may see nothing in the box.
  3. If any of the selected procedures contain parameters, the Stored Procedure Parameters dialog appears for you to input the required values. These values will be saved inside the stored procedure object, and will be used as the default value when executing this procedure. You can edit the stored procedure parameters at any time. For details, see Editing parameter values.
  4. When finished, click the Done button to close the dialog.

When a stored procedure has been added into a catalog, JReport will in turn do the following:

You will then be able to use the field objects to design your reports.

Notes:

Editing parameter values

When you add a stored procedure that contains parameters, you will be asked to input values for its parameters. These values will then be saved inside the stored procedure object in the catalog, and will be used as the default values when executing the stored procedure. You can edit stored procedure parameters at any time. Also, the IN type parameter is available for use with a stored procedure in a report the same as any other JReport parameter.

To edit the parameter values of a stored procedure:

  1. Right-click the stored procedure and click Parameters on the shortcut menu. The Stored Procedure Parameters dialog appears.

    Stored Procedure Parameters dialog

  2. This dialog lists all the IN and INOUT parameters in the stored procedures. Double-click the Value cell to edit the value of each parameter.
  3. Double-click the Bind Parameter Name cell to bind the IN and INOUT parameters in the stored procedure to an existing parameter or constant level formula of the same type predefined in the catalog data source in which the JDBC connection is created, or to the special field User Name. You can input the parameter/formula name as @fieldname; for the special field User Name as username. By default, the bound parameter will be the one with the same name of the IN and INOUT parameter which is automatically created when adding the stored procedure.
  4. Click OK to apply the changes to the parameters.

Updating stored procedures

If you make any changes to stored procedures in the database, you will need to update them in the connection so that the reports built on them can work properly.

  1. Select any stored procedure, right-click it, and click Update on the shortcut menu. The Update Procedures dialog appears.

    Update Procedures dialog

  2. Select the stored procedures you want to update, and then click the Update button.
  3. When finished, click the Done button to close the dialog.

Converting the data in stored procedures

JReport supports converting the data in stored procedures from one type to another before the data is passed to JReport. This assures that the row data in the database won't be affected. To do this, you will need to implement JReport interfaces and then JReport triggers your implementation to convert the data.

  1. Write a class to extend jet.universe.plugin.ResultSetConvertor in JREngine.jar in <install_root>\lib and implement the abstract method:

    public abstract ResultSet convert(final String catalogName, final String schemaName, final String procName,
    final ResultSet rs);

    There is a sample ResultSetConvertorImpl.java in <install_root>\help\samples\APIConvertData for your reference which is an example of converting String to Date and Time.

  2. Compile the class into a .jar file.
  3. Put the jar file in the jet.universe.customcolumn_2.0.0 folder located in the <install_root>\help\samples\APIConvertData directory.
  4. Modify the file plugin.xml located in the jet.universe.customcolumn_2.0.0 folder as follows:
  5. Move the two folders jet.universe.addcolumn_1.0.0 and jet.universe.customcolumn_2.0.0 from the <install_root>\help\samples\APIConvertData directory to the <install_root>\plugins directory.
  6. Start JReport Designer.

The conversion can also be done on JReport Server in the same way.

BackPrevious Page Next PageNext