Solved

Outputting timesheet totals

Posted on 2014-03-14
9
208 Views
Last Modified: 2014-03-25
Here is the table:

tracking_id, project_id, project_time, createdat

1,1,2.5,2014-03-10
2,1,3.5,2014-03-11
3,1,4.5,2014-03-12
4,1,5.5,2014-03-13
5,1,2.5,2014-03-14
6,2,3.5,2014-03-10
7,2,3.5,2014-03-11
8,2,3.5,2014-03-12
9,2,4.5,2014-03-13
10,2,4.5,2014-03-14


Title Line of Report

Totals for 8/10 - 8/14

Project ID | Mon | Tue | Wed | Thu | Fri


Where the day columns are the total from the database for that day for the project

1.  Some days might be missing.
2.  the date range is dynamic.

Here is what I have so far:

http://sqlfiddle.com/#!2/69e8f0/3


The query returns the results but not in a way I can easily generate an html table.


What I need to know: is their an easy way to rewrite the query so that there is 1 row per project_id and all the totals returned...

or how would I go about writing the PHP to output 1 row per project_id and the totals for the day columns.

Attached is a sample report, but it does not correlate with the data in the fiddle.
sample-report.PNG
0
Comment
Question by:rjohnsonjr
[X]
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
  • 5
  • 4
9 Comments
 
LVL 15

Expert Comment

by:gplana
ID: 39929560
Not sure if I understand your question, but I think this code is what you need (supposing you already have the connection made to mysql):

<table>
<?php
$strSQL = 'SELECT
	project_id,
	FROM_DAYS(TO_DAYS(createdat)) AS createdat,
	sum(project_time) AS project_time
FROM
	tracking
WHERE
	createdat >= \'2014-03-08\'
AND createdat <= \'2014-03-15\'
GROUP BY
	project_id,
	FROM_DAYS(TO_DAYS(createdat))';

$query = mysql_query($strSQL);
for ($i=0; $i<mysql_num_rows($query): $i++){
   $tracking_id = mysql_result($query,$i,0);
   $project_id = mysql_result($query,$i,1);
   $project_time = mysql_result($query,$i,2);
   $createdat = mysql_result($query,$i,3);
?>
<tr>
<td><?php echo $tracking_id; ?></td>
<td><?php echo $project_id; ?></td>
<td><?php echo $project_time; ?></td>
<td><?php echo $createdat; ?></td>
</tr>
<?php
   } // end of for
?>
</table>

Open in new window


Hope it helps. Regards.
0
 
LVL 6

Author Comment

by:rjohnsonjr
ID: 39929699
Sorry for not better explaining myself.

The issue I had and your code has is if there are 5 entries in the table for a project id, there will be 5 rows  in the output report and that is not what I want.

This might make it easier:


I want 1 row per project_id in the output report.

I want the totals for the particular date.

For project one I want the total hours for 3/10/2014 to be in the Monday column, the total hours for 3/11/2014 to be in the Tuesday column etc.
0
 
LVL 6

Accepted Solution

by:
rjohnsonjr earned 0 total points
ID: 39929813
So I found the solution to my problem I believe.  I needed to create a 2 dimensional array  where I create an entry in the array for each product id  and put set the columns to 0.00

Then I loop over the database and use the day of week to determine which column the total should go into.

This code needs cleaned up but should give you an idea.  it is a mix of php syntax and blade syntax at the moment.

<?php

$matrix = array();

?>

@foreach ($results as $result)

	@for ($i = 0; $i <= $total_days; $i++)
		<?php $matrix[$result->project_number][$i]=0.00; ?>
	@endfor

@endforeach

@foreach ($results as $result)

<?php

		$i++; 
		$line_total = 0.00;
		$grand_total = 0.00;
		$column_total = array();
		$day_of_week = date("w",strtotime($result->createdat));
		
		$matrix[$result->project_number][$day_of_week] = $result->project_time;
?>

Open in new window

0
Online Training Solution

Drastically shorten your training time with WalkMe's advanced online training solution that Guides your trainees to action. Forget about retraining and skyrocket knowledge retention rates.

 
LVL 15

Expert Comment

by:gplana
ID: 39929826
Oh, sorry, I didn't understood.

I think you should just remove last line on the group by so only the project id is on your group by clause.

So change this:
$strSQL = 'SELECT
	project_id,
	FROM_DAYS(TO_DAYS(createdat)) AS createdat,
	sum(project_time) AS project_time
FROM
	tracking
WHERE
	createdat >= \'2014-03-08\'
AND createdat <= \'2014-03-15\'
GROUP BY
	project_id,
	FROM_DAYS(TO_DAYS(createdat))';

Open in new window


to this:

$strSQL = 'SELECT
	project_id,
	FROM_DAYS(TO_DAYS(AVG(createdat))) AS createdat,
	sum(project_time) AS project_time
FROM
	tracking
WHERE
	createdat >= \'2014-03-08\'
AND createdat <= \'2014-03-15\'
GROUP BY
	project_id;

Open in new window


and let me know if this works.
0
 
LVL 6

Author Comment

by:rjohnsonjr
ID: 39929934
if you do that then only 1 date is returned instead of all dates
0
 
LVL 15

Expert Comment

by:gplana
ID: 39929940
Yes, but isn't this what you want? Don't you sant just one record by project?
0
 
LVL 6

Author Comment

by:rjohnsonjr
ID: 39929960
I want 1 project_id row but the totals for each date
0
 
LVL 15

Expert Comment

by:gplana
ID: 39929968
Not sure if I understand. If you have these rows:

Project   date
1              Today
1              Tomorrow
2              Today
2              Tomorrow

Which rows do you want to be on the resultset?
0
 
LVL 6

Author Closing Comment

by:rjohnsonjr
ID: 39952706
The 2 dimensional array was the key as explained in my post.  Thanks to those that tried to help
0

Featured Post

Guide to Performance: Optimization & Monitoring

Nowadays, monitoring is a mixture of tools, systems, and codes—making it a very complex process. And with this complexity, comes variables for failure. Get DZone’s new Guide to Performance to learn how to proactively find these variables and solve them before a disruption occurs.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
Session time out quickly. 6 53
Building a glossary into your website 9 58
JSON decode 5 43
Select Query Fails in PHP but not in TERMINAL Mysql 9 29
Part of the Global Positioning System A geocode (https://developers.google.com/maps/documentation/geocoding/) is the major subset of a GPS coordinate (http://en.wikipedia.org/wiki/Global_Positioning_System), the other parts being the altitude and t…
3 proven steps to speed up Magento powered sites. The article focus is on optimizing time to first byte (TTFB), full page caching and configuring server for optimal performance.
The viewer will learn how to count occurrences of each item in an array.
The viewer will learn how to create and use a small PHP class to apply a watermark to an image. This video shows the viewer the setup for the PHP watermark as well as important coding language. Continue to Part 2 to learn the core code used in creat…

737 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