
The count of operator counts how many records in a related table match the specified selection criteria. The result can appear as a list item in the detail area of a report or as a statistic in the summary area at the end of a report.
There's an important difference between the conditional statistical operator count and the relational statistical operator count of. count finds the number of records that satisfy a specified condition among the records being processed. count of calculates the number of matching records related to the records being processed by the script.
TABLENAME
You can use Count of directly on a table without a predefined Relationship. Just remember that if there is a Relationship defined that doesn't have an alternative relationship name, this relationship will be named the same and the table and be used.
RELATIONSHIP
If you use a relationship (alternative name) then the count of will be automatically restricted by the relational restriction. Read under TABLENAME for functionality when using Relationships without alternative relational name.
NAMED "Unique Relationship Name"
You can define an ad hoc named relationship directly in the Count Of function. If you do this you will possibly achieve two things. 1) You will insure against DataEase using a pre-defined relationship with the same name as the table. 2) You can re-use it again in the same script i.e. on a Sum Of etc.
WITH {selection criteria}
With the WITH statement you define the relational restriction of the function. Ex. MyCustomerNR=CustomerNR and MyDate>current date.
Example 1
In a field derivation.Simplest type. We have two tables. ThisTable and MyCustomers. We have no relationships defined.
count of MyCustomers
This will return the number i have.
Example 2
We have two tables.CustomerType and MyCustomers. We have a relationship between them that connect CustomerType and MyCustomers on customer type.There is no Unique Alternative Name for the Relationship. I have 300 records in MyCustomer and 45 of type Good Credit.
My active record in CustomerType is the Good Credit record.
count of MyCustomers
This will return the number 45 as I am now using the relationship instead of the table.
count of MyCustomers named "AllRecords"
Example 3
count of MyCustomers named "NewRel" with RegistrationDate=current date
This will return the number of customers registered today.
Example 4
for MEMBERS with STATE = "CA" ;
list records
LASTNAME in order ;
TOTAL DUE ;
TOTAL DUE > 100 : item count ;
count of RESERVATIONS with ( TOTAL DUE > 1500) .
end
Relational Statistical Operator
The count of operator counts how many records in a related table match the specified selection criteria. The result can appear as a list item in the detail area of a report or as a statistic in the summary area at the end of a report.
There's an important difference between the conditional statistical operator count and the relational statistical operator count of. count finds the number of records that satisfy a specified condition among the records being processed. count of calculates the number of matching records related to the records being processed by the script.
count of TABLENAME|RELATIONSHIP
[named "UNIQUE RELATIONSHIP NAME" ]
[with ( selection criteria) ] ;|.
for MEMBERS with STATE = "CA" ;
TOTAL DUE ;
TOTAL DUE > 100 : item count ;
count of RESERVATIONS with ( TOTAL DUE > 1500) .
This script tells DataEase: (1) Process all the MEMBERS records of members living in California, (2) list the LAST NAME and TOTAL DUE field from each MEMBERS record, (3) for each member, display a YES or NO answer indicating if the member's TOTAL DUE is greater than $100, (4) count the total number of members whose TOTAL DUE is greater than $100 and display this total as a statistic at the end of the report output (this is generated by the count operator), and (5) count the number of related RESERVATIONS records that have a TOTAL DUE greater than $1500, and display this number as a list item for each member (this is generated by the count of operator).
Product: Dataease [{8}]FIVE. Written by George Washington 16/10/15 at 07:08:04
Product: Dataease [{8}]FIVE. Written by DataEase 16/10/15 at 12:07:02
Product: Dataease [{8}]FIVE. Written by George Washington 16/10/15 at 14:36:15
Product: LegEasy DOS. Written by Simon Lazarus 01/05/20 at 13:13:05
Product: LegEasy DOS. Written by DataEase 01/05/20 at 13:22:09
Product: LegEasy DOS. Written by Simon Lazarus 01/05/20 at 13:38:55
Product: LegEasy DOS. Written by DataEase 01/05/20 at 17:20:18
Product: LegEasy DOS. Written by Simon Lazarus 04/05/20 at 13:07:53
Product: LegEasy DOS. Written by Earl Wertheimer 05/05/20 at 20:29:59