Skip Headers
Oracle® Reports Building Reports
10g Release 2 (10.1.2)
B13895-01
  Go To Documentation Library
Home
Go To Product List
Solution Area
Go To Table Of Contents
Contents
Go To Index
Index

Previous
Previous
Next
Next
 

23 Building a Report with Conditional Highlighting

In this chapter, you will learn about reports that display highlighted values based on one or more conditions. By following the steps in this chapter, you can generate the report output shown in Figure 23-1.

Figure 23-1 Conditional highlighting report output

Description of Figure 23-1  follows
Description of "Figure 23-1 Conditional highlighting report output"

Concepts

Data Relationships

This report uses one query to fetch all data.

Layout

This report uses a tabular layout style. To add conditional highlighting, you will use the Conditional Formatting dialog box to determine which names and salaries will be highlighted in the report output.

Example Scenario

In this example, you will create a report for managers that shows a complete list of employees in the company, but also highlights employee salaries that are greater than or equal to $10,000. You also need to indicate which employees' salaries are between $4,999 and $10,000. In this example, you will use conditional formatting to highlight these figures in bold and red text.

As you build this example report, you will:

To see a sample report that uses conditional highlighting, open the examples folder named condhigh, then open the Oracle Reports example report named condhigh.rdf. For details on how to open it, see "Accessing the Example Reports" in the Preface.

23.1 Prerequisites for this example

To build the example in this chapter, you must have access to the Human Resources sample schema (HR) provided with the Oracle Database. If you do not know if you have access to this sample schema, contact your database administrator.

23.2 Create a basic tabular report

The steps in this section will show you how to use the Report Wizard to build a simple tabular report.

To create a tabular report:

  1. Launch Reports Builder (or, if already open, choose File > New > Report).

  2. In the Welcome or New Report dialog box, select Use the Report Wizard, then click OK.

  3. If the Welcome page displays, click Next.

  4. On the Report Type page, select Create Paper Layout Only, then click Next.

  5. On the Style page, type a Title for your report, select Tabular, then click Next.

  6. On the Data Source page, click SQL Query, then click Next.

  7. On the Data page, enter the following SELECT statement in the Data Source definition field:

    SELECT ALL EMPLOYEES.FIRST_NAME, EMPLOYEES.LAST_NAME,
    EMPLOYEES.EMPLOYEE_ID, EMPLOYEES.SALARY
    FROM HR.EMPLOYEES
    

    Note:

    You can enter this query in any of the following ways:
    • Copy and paste the code from the provided text file called condhigh_code.txt into the Data Source definition field.

    • Click Query Builder to build the query without entering any code manually.

    • Type the code in the Data Source definition field.


  8. Click Next.


    Note:

    If you are not already connected to a database, you will be prompted to connect to the database when you click Query Builder or Next. Ensure that you connect to a database that has the appropriate schema for this example. Section 23.1, "Prerequisites for this example" describes the sample schema requirements for this example.

  9. On the Fields page, click the right arrow (>) to move the following fields to the Displayed Fields list, then click Next. Make sure you move them in the following order:

    • EMPLOYEE_ID

    • FIRST_NAME

    • LAST_NAME

    • SALARY

  10. On the Totals page, click Next.

  11. On the Labels page, click Next.

  12. On the Template page, select Predefined Template and click Beige, then click Finish to preview your report output in the Paper Design view. It should look something like this:

    Figure 23-2 Paper Design view for the initial tabular report

    Description of Figure 23-2  follows
    Description of "Figure 23-2 Paper Design view for the initial tabular report"

Now, let us format the data to make it more meaningful.

To format the report:

  1. In the Paper Design view, select the Salary column by clicking once on the column of data.

  2. Click the Currency button in the toolbar. A currency symbol immediately appears next to all of the values.

  3. Click the Commas button.

  4. Click the Add Decimal button twice. Two decimal places are added to the right of the decimal point.

    The Salary column of your report should now look like this:

    Figure 23-3 Formatted salary column

    Description of Figure 23-3  follows
    Description of "Figure 23-3 Formatted salary column"

  5. Change the alignment of your columns by doing the following:

    1. Click the Salary column heading, then click the Align Center button in the toolbar.

    2. Click the Salary column once, then click the Align Right button in the toolbar.

    3. While the Salary column is selected, Shift-click to select the column heading too, then click and drag one of the right black squares to size the column and column heading.

    4. Click the Employee Id column heading, Shift-click to select the Employee Id column too, then click the Align Center button in the toolbar.

  6. The Paper Design view of your report should now look like this:

    Figure 23-4 Paper Design view of the tabular report

    Description of Figure 23-4  follows
    Description of "Figure 23-4 Paper Design view of the tabular report"

  7. Save your report as condhigh_your_initials.rdf.

23.3 Add conditional formatting to the report

The steps in this section will show you how to add conditional formatting so that salaries greater than or equal to $10,000 will be highlighted in bold, red text, and salaries between $4,999 and $10,000 will be highlighted in bold text.

Since the data retrieved cannot be both greater than or equal to $10,000 and between $4,999 and $10,000, you will need to create two separate format exceptions. In this section, you will see how to create each distinct format exception.

To add conditional formatting:

  1. In the Paper Design view, right-click the Salary column of data (not the Salary column heading), then choose Conditional Formatting.

  2. In the Conditional Formatting dialog box, click New to create a new Format Exception.

  3. In the Format Exception dialog box, make sure SALARY is selected.

  4. Next to SALARY, choose Greater Than or Equal from the list.

  5. In the next box, type 10000.

  6. Under Format, click the icon next to Text Color to display the color palette.


    Note:

    You can choose as many options as you want in the Format Exception dialog box, such as text color, style, and font.

  7. Click Red.

  8. Click Font, then choose Bold.

  9. Click OK to accept the new font style.

    You should now see the following options selected in the Format Exception dialog box:

    Figure 23-5 Format Exception dialog box

    Description of Figure 23-5  follows
    Description of "Figure 23-5 Format Exception dialog box"

  10. Click OK.

  11. In the Conditional Formatting dialog box, click New to create your second format exception.

  12. Create a format exception where the values of the SALARY column are between $4999 and $10000 are highlighted in bold.


    Note:

    Make sure you type the values in the order described, so that Reports Builder knows to highlight the data between $4999 and $10000, and not $10000 and $4999.

  13. When you are done, click OK. The Conditional Formatting dialog box should now look like the following:

    Figure 23-6 Conditional Formatting dialog box

    Description of Figure 23-6  follows
    Description of "Figure 23-6 Conditional Formatting dialog box"

  14. Click Apply, then click OK. Your report displays in the Paper Design view, and should now look something like this:

    Figure 23-7 FInal Conditional Formatting report

    Description of Figure 23-7  follows
    Description of "Figure 23-7 FInal Conditional Formatting report"

  15. Save your report as condhigh_your_initials.rdf.

23.4 Examine the conditional format trigger code

The steps in this section will show you the PL/SQL code that was automatically generated by Reports Builder when you used the Conditional Formatting dialog box to set up your format exceptions.


Note:

You can also edit the conditional format trigger code in the PL/SQL Editor, but if you attempt to modify the code again in the Conditional Formatting dialog box, your edits will be overwritten by the selections in the dialog box. If you do modify the code in the PL/SQL Editor, you will see a warning note when you try to open the Conditional Formatting dialog box.

To examine the automatically generated code:

  1. In the Paper Design view, right-click the Salary column (on which you just applied formatting), then choose PL/SQL Editor.

  2. In the PL/SQL Editor, you will see the following code that was automatically generated by Reports Builder.

Figure 23-8 PL/SQL code for the new format triggers

Description of Figure 23-8  follows
Description of "Figure 23-8 PL/SQL code for the new format triggers"


Note:

In this code, you can see that the two format exceptions you created comprise two parts of a format trigger. You needed to create two separate format exceptions in the Conditional Formatting dialog box to achieve this effect. If you had tried to create both exceptions simultaneously in the same Format Exception dialog box, your data would not have satisfied both exceptions, and thus would not have been highlighted.

23.5 Summary

Congratulations! You have successfully built a report that highlights specified data in the report output. You now know how to:

For more information on any of the wizards, views, or properties used in this example, refer to the Oracle Reports online Help, which is available in Reports Builder or hosted on the Oracle Technology Network (OTN), as described in Section 3.1.1, "Using the Oracle Reports online Help".