Crystal Reports Formula

Posted on 2014-04-22
Last Modified: 2014-05-05
Using the following information, how do I do a formula for this.

Student get enrolled into our classes every Monday.  So our first day of classes started on 04/07/14.  In my table this is a datetime field.  There is a possibility of 78 hours for this quarter.  What I need help with is figure out the 90% attendance for these students.

Does this make sense?  No sure if I am explaining this right.
Question by:TCHGirl
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 3
  • 3

Expert Comment

ID: 40016150
what database language are you using to get the it SQL server?

The reason, i ask is because it would be much easier and faster to get the output values if you can get it done directly in SQL and use that value in the report

Author Comment

ID: 40016228
I am using SQL.  But the reports that everybody uses in Crystal.
LVL 100

Assisted Solution

mlmcc earned 500 total points
ID: 40016599
I am guessing this is for a class or a training course you are taking.

Do you need the answer in Crystal?

You need to add a group on the student.
Sum the hours attended
Sum the hours available
In the group footer
Calculate the percentage

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!


Author Comment

ID: 40029726
Yes I do need this in Crystals.  Is there not an easier way to do this?  Crystal has a place for SQL Expressions.  So how would I do the above?
LVL 100

Accepted Solution

mlmcc earned 500 total points
ID: 40030154
What does the report show now?
You should be able to get the SUM of the hours attended and available and do the calculation in a formula

Sum({HoursSttendedFIeld},{StudentIdField}) / Sum({HoursAvailableField},{StudentIdField})


Author Comment

ID: 40042078
Right now the report does not have this in it.  I have been putting information into a difference table.  So what I am trying to do is eliminate that table and save myself some extra steps.

The formula needs to also be based of when the student started the class because not all the students start class the same day.

So if the student started classes on 04/21/2014 then there are 31 days left in the quarter  x 2 hours a day..  In order for the student to reach 90% then he has to attend classes for 56 hours.  If he attends 56 hours of class then the line says "you reached 90%", if it is less than 56 hours then the line says "you did not reach 90%".

So this what I want to have printed on my report.  But in a formula.  Is this possible?
LVL 100

Assisted Solution

mlmcc earned 500 total points
ID: 40042270
What information is in the report?

To get what you want you will need
1.  Dates/times student attended
2.  Date/times scheduled for class
3.  Date student started attendance
4.  Date student ended attendance


Featured Post

On Demand Webinar - Networking for the Cloud Era

This webinar discusses:
-Common barriers companies experience when moving to the cloud
-How SD-WAN changes the way we look at networks
-Best practices customers should employ moving forward with cloud migration
-What happens behind the scenes of SteelConnect’s one-click button

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

I hate sub reports and always consider them the last resort in any reporting solution.  The negative effect on performance and maintainability is just not worth the easy ride they give the report writer.  Nine times out of ten reporting requirements…
Today, still in the boom of Apple, PC's and products, nearly 50% of the computer users use Windows as graphical operating systems. If you are among those users who love windows, but are grappling to keep the system's hard drive optimized, then you s…
Finds all prime numbers in a range requested and places them in a public primes() array. I've demostrated a template size of 30 (2 * 3 * 5) but larger templates can be built such 210  (2 * 3 * 5 * 7) or 2310  (2 * 3 * 5 * 7 * 11). The larger templa…

749 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question