- •Welcome to Seagate Crystal Reports
- •Welcome
- •Two kinds of Hands-On tutorials
- •Command, button, key, and control conventions
- •Using Seagate Crystal Reports documentation
- •Seagate Crystal Reports online Help features
- •If you need more help...
- •Installation Requirements
- •Installing Seagate Crystal Reports
- •Installing on a network workstation
- •Upgrading from a previous version
- •Quick Start
- •Subreports expand report usefulness
- •Query Designer adds ad-hoc querying capabilities
- •Parameter fields mean multi-purpose reports
- •Text objects give you text with intelligence
- •Preprinted-form reports easier than ever
- •More powerful formulas extend your capabilities
- •Web solution serves up variety of online reports
- •HTML exporting simplifies Web activities
- •New database support improves data access
- •Running totals made easy
- •Smart Navigation
- •Learning Seagate Crystal Reports
- •User’s Guide
- •Online Help
- •Books Online
- •Sample Reports
- •Glossary
- •Sample Data - CRAZE.MDB
- •Suggested learning paths
- •The application window
- •Menu bar
- •Standard toolbar
- •Supplementary toolbar
- •Format bar
- •Status bar
- •Shortcut menus
- •Cursors
- •Design Tab
- •Preview Tab
- •Other fundamentals
- •HANDS-ON (Report Design Environment)
- •How to add, delete, and move guidelines
- •How to move and position objects using guidelines
- •How to turn the grid on/off
- •How to zoom your report in and out
- •How to undo/redo activities
- •How to drill down on summarized data
- •HANDS-ON (Sections and Areas)
- •How to add, delete, move, and merge sections
- •How to split and resize sections
- •Basic report design
- •How to design a prototype
- •Concepts in reporting
- •Beyond basic reports
- •HANDS-ON (Report Creation and Design)
- •How to select data and begin creating a report
- •How to add and link multiple tables
- •How to insert database fields
- •How to insert special fields
- •How to insert a page n of N field
- •How to insert text objects
- •How to use a database field in a text object
- •How to insert a picture
- •How to select, move, and resize objects
- •How to hide parts of the report
- •HANDS-ON (Finishing Your Report)
- •How to insert page headers and footers
- •How to add a title page to your report
- •How to add summary information to your report
- •Printing considerations
- •Design solutions for printing/distributing
- •Report creation checklist for distributed reports
- •Updating printer drivers
- •Report distribution
- •HANDS-ON (Distributing Your Report)
- •How to export reports
- •How to fax a report
- •How to request reports from a web browser
- •How to specify parameter field values
- •How to log on to a database
- •How to view plain HTML reports
- •Overview
- •Getting started
- •Record Selection
- •Grouping and sorting
- •Completing the report
- •Introduction
- •Working with Arbor Essbase data
- •HANDS-ON (Reporting on OLAP data)
- •How to create a cross-tab with Essbase data
- •Using multiple sections in reports
- •HANDS-ON (Multiple Section Reports)
- •How to work with text objects
- •How to create a form letter using a text object
- •How to format objects conditionally
- •How to print conditional messages in form letters
- •How to alternate background colors for rows
- •How to eliminate blank lines
- •How to add blank lines conditionally
- •Formatting concepts
- •Absolute formatting
- •Types of formatting properties
- •Conditional formatting
- •HANDS-ON (Absolute Formatting)
- •How to add color, shading, and borders
- •How to add/edit lines and boxes
- •How to change margins
- •How to add/delete white space between rows
- •How to set page orientation and paper size
- •HANDS-ON (Conditional Formatting)
- •How to flag values that meet certain conditions
- •Record selection
- •Group selection
- •Record selection formula templates
- •HANDS-ON (Record and Group Selection)
- •How to create a record or group selection formula
- •How to use record/group selection templates
- •How to select the top or bottom N groups
- •Sorting, Grouping, and Totalling Overview
- •Creating custom groups
- •HANDS-ON (Sorting, Grouping, and Totalling)
- •How to do a single field sort
- •How to do a multiple field sort
- •How to group data
- •How to sort records within groups
- •How to summarize grouped data
- •How to subtotal grouped data
- •How to sort based on summarized group values
- •How to create multiple levels of subtotals
- •How to group data in intervals
- •How to calculate a percentage of the grand total
- •How to create group headers
- •What are formulas?
- •Other formula conventions
- •Formula syntax
- •How formulas are evaluated - Order of precedence
- •HANDS-ON (Formulas 101)
- •How to insert a formula in your report
- •How to delete formulas from your report
- •How to copy formulas from online Help
- •How to copy formulas from one report to another
- •How to create if-then-else formulas
- •How to format text with formulas
- •How to use variables in formulas
- •How to declare a variable
- •How to assign a value to a variable
- •How to conditionally assign values to variables
- •How to use an array in a formula
- •How to use a range in a formula
- •How to use semicolons in formulas
- •How to fine tune group selection formulas
- •How to fine tune record selection formulas
- •How to debug a formula
- •Introduction
- •HANDS-ON (Advanced Totalling)
- •How to maintain running totals in a list
- •How to subtotal running totals within groups
- •How to subtotal without grouping
- •How to subtotal true A to B, A to C reports
- •Parameter field objects overview
- •Multiple parameter fields
- •Parameter field considerations
- •HANDS-ON (Parameter Field Objects)
- •How to create a parameter field
- •How to use a parameter field in a formula
- •How to respond to parameter field prompts
- •How to use wildcards with parameter fields
- •How to set a report title using parameter fields
- •How to set sort order using parameter fields
- •Graphing Overview
- •Choosing a graph or chart type
- •Where to place your graph
- •Data you can graph on
- •Before you create your graph
- •HANDS-ON (Graphing)
- •How to graph on a summary or subtotal field
- •How to graph on a details field
- •How to graph on a formula field
- •How to graph on cross-tab summaries
- •How to edit graphs using PGEditor
- •How to use the underlay feature with graphs
- •OLE Objects Overview
- •Inserting OLE objects in your reports
- •Linked vs. Embedded Objects
- •The dynamic OLE menu commands
- •OLE and the Picture command
- •General OLE considerations
- •HANDS-ON (OLE Objects)
- •How OLE objects are represented in your report
- •How to use OLE - General Overview Tutorial
- •How to insert a graphic/picture as an OLE object
- •What are subreports?
- •Unlinked vs. linked subreports
- •How subreport linking works
- •HANDS-ON (Subreports)
- •How to insert a subreport
- •How to preview your subreport
- •How to combine unrelated reports using subreports
- •How to use subreports with unlinkable data
- •Cross-tab overview
- •Cross-tab components
- •HANDS-ON (Cross-Tab Objects)
- •How to create a cross-tab object
- •How to format a cross-tab
- •How to print cross-tabs that span multiple pages
- •The Crystal Query Designer
- •HANDS-ON (Queries)
- •How to create a new query
- •How to add tables to a query
- •How to link tables and specify a join type
- •How to add fields to a query
- •How to identify unique values in a query
- •How to summarize data with aggregate functions
- •How to sort records according to field values
- •How to specify records to be included in a query
- •How to select groups to be included in a query
- •How to create an SQL expression
- •How to create a query from another Crystal Query
- •How to select a query for a report
- •How to use a parameter field in a query
- •Dictionaries Overview
- •HANDS-ON (Dictionaries)
- •How to create a new dictionary
- •How to add a data file
- •How to open an SQL or ODBC data source
- •How to link multiple tables
- •How to select tables and fields for users
- •How to add/create formulas
- •How to move fields/field headings within the list
- •How to update the location of a database table
- •How to add a new field heading
- •How to add Help text
- •How to add a graphic
- •How to create sample data for users to browse
- •How to edit an existing dictionary
- •How to convert a 3.x or 4.x dictionary file
- •How to select a dictionary for a report
- •Databases Overview
- •For additional information
- •HANDS-ON (Working With Databases)
- •How to open Access queries through DAO
- •How to open Access queries through ODBC
- •How to open Access parameter queries
- •How to set up an ODBC data source
- •How to check settings for an ODBC data source
- •How to log on to an ODBC data source
- •How to add an ODBC database table to a report
- •How to log on to MS SQL Server via ODBC
- •How to log off an ODBC data source
- •How to set up an A to B, A to C link
- •How to edit an SQL query
- •How to use an ACT! database
- •How to open the NT Event Log
- •Introduction
- •Four types of data
- •Direct access database files
- •ODBC data sources
- •Crystal Query Designer files
- •Crystal Dictionary files
- •Multi-pass reporting
- •Product support
- •Web support
- •E-mail support
- •Fax support
- •Telephone support
- •Extended technical support policy
- •Product registration
- •Product return policy
- •Product replacement policy
- •Glossary
Introduction
Advanced totalling is any kind of report totalling that requires the extensive use of formulas. Tutorials included in this chapter demonstrate the techniques needed to produce many of the most common reports that require advanced totalling. Each tutorial takes you step-by-step through the process of creating the report and adding the necessary formulas.
The topics covered in this chapter are advanced techniques. Before starting, you should be familiar with how to design reports in Seagate Crystal Reports, how to group values in a report and how to summarize data. You should also know how to use the formula language, including variables, to create formulas and add them to a report.
Related Topics
Sorting, Grouping, and Totalling, Page 271
Formulas 101, Page 321
Advanced Formulas, Page 345
Search for Functions Index in Seagate Crystal Reports online Help.
HANDS-ON (Advanced Totalling)
How to maintain running totals in a list
Running totals are totals that are displayed generally on a record by record basis. They total all records (in the report, in the group, and so forth) up to and including the current record. For example, if your first three records have values of 2, 4, and 6, the running total for each of the three records would be as follows:
Values |
Running Total |
|
|
|
|
2 |
2 = 0 + 2 |
|
|
4 |
6 = 2 + 4 |
|
|
6 |
12 = 6 + 6 |
|
|
378 |
Seagate Crystal Reports User’s Guide |
The most basic form of running total is a single running total maintained throughout a list. In this tutorial you will create that kind of report, setting up a running total for a list of order amounts.
To set up this report, you will create two formulas:
1.ResetTotal
This formula resets the Amount variable to $0.00 at the beginning of the report.
2.@RunningTotal
This formula adds the value of the current record to the Amount variable and displays the current total as the running total.
NOTE: To see an example of this report, open the report file RTO1.RPT located in the \CRW directory.
To get started, create a report using the sample data, CRAZE.MDB, link the Customers and Orders tables, and place the following fields from left to right in the Details section:
{customer.CUSTOMER NAME} {orders.ORDER ID} {orders.ORDER AMOUNT}
Create a formula named ResetTotal and enter the following in the Formula Editor:
ResetTotal (“Amount”)
This formula says:
Reset the value in the Amount variable to $0.00.
!Place the formula in the Report Header section of your report. Since it’s in the Report Header section, it will run only once, at the beginning of the report.
"Right-click the @ResetTotal field and choose the FORMAT FIELD command from the shortcut menu that appears. The Format Editor appears.
# Click the Common Tab to activate it.
Advanced Totalling |
379 |
$Toggle the Suppress option on to hide the field from view when printing, and click OK when finished to return to your report.
%Create a formula named RunningTotal and enter the following into the Formula Editor:
RT (“Amount”, “Sum”, ToNumber ({orders.ORDER AMOUNT}), {customer.CUSTOMER NAME})
This formula says:
Convert the value in the {orders.ORDER AMOUNT} field to a number (if necessary), add the value in that field to the Amount variable, and keep track of the customer name.
NOTE: If you have NULL values in the field you are performing a running total on, you will have to add code to check for NULL values or toggle the Convert NULL field value to default check box
on using the Reporting Tab of the File Options dialog box. Search for File Options dialog box in online Help.
&Place this formula in the Details section of your report, just to the right of the Order Amount field.
NOTE: When you place @RunningTotal in the Details section of the report, the formula executes for every record, thus keeping a running total of the Order Amount field. See Area printing
characteristics, Page 69.
Your report should look similar to the following:
NOTE: This example report has been designed to illustrate concepts only, not the actual look of your finished report.
380 |
Seagate Crystal Reports User’s Guide |
The value in each record is added to the sum of the previous value in the report.
The total continues, unbroken, throughout the running list.
Related Topics
How to subtotal running totals within groups, Page 381
Formulas 101, Page 321
Advanced Formulas, Page 345
Reporting 101, Page 95
How to subtotal running totals within groups
Another common use of running totals is for tallying items in a group. The running total starts with the first item in the group and ends with the last. Then it starts all over again for the next group, then the next, and so on.
Advanced Totalling |
381 |
In this example, you will create a report that:
●maintains a running total of customer orders,
●groups customer orders and resets the running total for each group, and
●displays the subtotal for each order (the last running total for that order).
To set up this report, you will create three formulas:
1.ResetTotal
Sets the value of the Amount variable to $0.00 at the beginning of each group.
2.RunningTotal
Adds the value of the current record to the Amount variable, and displays the current total as the running total.
3.PrintTotal
Prints the final running total value for the group as the group subtotal.
NOTE: To see an example of this report, open the report file RTO2.RPT in the \CRW directory.
To get started, create a report using the sample data, CRAZE.MDB, link the Customers and Orders tables and place the following fields from left to right in the Details section:
{customer.CUSTOMER NAME} {orders.ORDER ID} {orders.ORDER AMOUNT}
Create a formula named ResetTotal and enter the following in the Formula Editor:
ResetTotal (“Amount”)
This formula says:
Reset the value in the “Amount” variable to $0.00.
!Place this formula in the Group Header section of your report. Since it’s in the Group Header section, it will run each time a new group is started. See Area printing characteristics, Page 69.
382 |
Seagate Crystal Reports User’s Guide |
"Right-click the @ResetTotal field and choose the FORMAT FIELD command from the shortcut menu that appears. The Format Editor appears.
# Click the Common Tab to activate it.
$Toggle the Suppress option on to hide the field from view when printing, and click OK when finished to return to your report.
%Create a formula named RunningTotal and enter the following into the Formula Editor:
RT (“Amount”, “Sum”,ToNumber({Orders.Order Amount}),{Customer.Customer Name})
This formula says:
Convert the value in the {orders.ORDER AMOUNT} field to a number (if necessary), add the value in that field to the Amount variable, and keep track of the customer name.
NOTE: If you have NULL values in the field you are performing a running total on, you will have to add code to check for NULL values or toggle the Convert NULL field value to default check box
on using the Reporting Tab of the File Options dialog box. Search for File Options dialog box in online Help.
&Place this formula in the Details section of your report, just to the right of the Order Amount field.
NOTE: When you place @RunningTotal in the Details section of the report, the formula executes for every record, thus keeping a running total of the Order Amount field. See Area printing
characteristics, Page 69.
Your report should look similar to the following:
NOTE: This example report has been designed to illustrate concepts only, not the actual look of your finished report.
Advanced Totalling |
383 |