Q

# Maximum of 5-day running totals

## I have a table of dates and number of events per date. I need to find a 5-day range where the most number of events happened. I just couldn't figure out a way to sum up the values of events-per-date for every 5 rows. This means all possible 5 consecutive rows, but dates are not necessarily consecutive (days where no events occurred are not kept).

I have a table of dates and number of events per date. I need to find a 5-day range where the most number of events...

happened. I just couldn't figure out a way to sum up the values of events-per-date for every 5 rows. This means all possible 5 consecutive rows, but dates are not necessarily consecutive (days where no events occurred are not kept).

```eventdate  numevents
2006-06-16    3
2006-06-17    3
2006-06-18    3
2006-06-19    3
2006-06-20    4
2006-06-21    4
2006-06-22    4
2006-06-23    4
2006-06-24    3
2006-06-25    2
2006-06-26    2
2006-06-27    2
2006-06-30    2
2006-07-01    2
2006-07-04    1```

This is only a very small section of the table.

What an interesting problem. Thanks for sending it in.

The solution requires a self-join. What we need to do is join the table to itself, with a special condition: each row must be joined only to itself and the immediately preceeding four rows. In other words, we join each row to the top 5 rows that have an eventdate that is equal to or less than that row. Please make sure you understand this statement of the problem before looking at the following SQL:

```select t1.eventdate
, t1.numevents
, t2.eventdate
, t2.numevents
from events as t1
inner
join events as t2
on t2.eventdate <= t1.eventdate
and 5 >=
( select count(*)
from events
where eventdate
between t2.eventdate
and t1.eventdate )
order
by t1.eventdate
, t2.eventdate```

The above query produces the following results:

```t1             t2
2006-06-16  3  2006-06-16  3

2006-06-17  3  2006-06-16  3
2006-06-17  3  2006-06-17  3

2006-06-18  3  2006-06-16  3
2006-06-18  3  2006-06-17  3
2006-06-18  3  2006-06-18  3

2006-06-19  3  2006-06-16  3
2006-06-19  3  2006-06-17  3
2006-06-19  3  2006-06-18  3
2006-06-19  3  2006-06-19  3

2006-06-20  4  2006-06-16  3
2006-06-20  4  2006-06-17  3
2006-06-20  4  2006-06-18  3
2006-06-20  4  2006-06-19  3
2006-06-20  4  2006-06-20  4

2006-06-21  4  2006-06-17  3
2006-06-21  4  2006-06-18  3
2006-06-21  4  2006-06-19  3
2006-06-21  4  2006-06-20  4
2006-06-21  4  2006-06-21  4

and so on```

Notice that the first four t1 dates do not have five preceeding t2 dates. We'll come back to that in a moment.

Now that we know we're looking at the right data, we can do the next step, which is to add up the numevents values for the joined t2 rows. We do this by changing the query into a GROUP BY query:

```select t1.eventdate
, count(*)          as rows
, sum(t2.numevents) as total
from events as t1
inner
join events as t2
on t2.eventdate <= t1.eventdate
and 5 >=
( select count(*)
from events
where eventdate
between t2.eventdate
and t1.eventdate )
group
by t1.eventdate```

The above query produces the following results:

```eventdate  rows total
2006-06-16  1     3
2006-06-17  2     6
2006-06-18  3     9
2006-06-19  4    12
2006-06-20  5    16
2006-06-21  5    17
2006-06-22  5    18
2006-06-23  5    19
2006-06-24  5    19
2006-06-25  5    17
2006-06-26  5    15
2006-06-27  5    13
2006-06-30  5    11
2006-07-01  5    10
2006-07-04  5     9 ```

Notice that we can add HAVING COUNT(*)=5 to this query if we wish to eliminate the first four dates.

The final step is to take the maximum of the total column, and there are a number of ways to do it, which we don't really have room to discuss. The easiest is to add ORDER BY total DESC to the above query, and, by inspection, take the first result row. Caution: look for ties for the maximum, as there are in this case for the 23rd and 24th.

This was last published in October 2006

## Content

Find more PRO+ content and other member only offers, here.

#### Have a question for an expert?

Get answers from a TechTarget expert on whatever's puzzling you.

You will be able to add details on the next page.

#### Start the conversation

Send me notifications when other members comment.

## SearchDataManagement

• ### With better scaling, semantic technology knocks on enterprise's door

Cambridge Semantics CTO Sean Martin says better scalability can lead to richer representations of data. Such advances are behind ...

• ### Big data management and analytics weather tumult -- with more in store

Cloud had a big impact on big data management and analytics last year. Machine learning and streaming designs will contribute to ...

• ### Embedded analytics to feel widest impact of machine learning projects

Ovum analyst Tony Baer discusses machine learning tools, IoT-driven streaming analytics and Hadoop in the cloud, all of which ...

• ### With AI tools, enterprises need to differentiate between hype and value

Enterprises can reap real value by implementing AI applications, but seeing that value through the fog of hype can be difficult, ...

• ### Cognitive computing applications present new business challenges

When implementing cognitive software, enterprises need to worry just as much -- if not more -- about the business implications, ...

• ### Researchers work on AI algorithms to detect fake news

A new challenge to identify fake news will test the boundaries of AI technology and offer a proving ground for innovative new ...

## SearchSAP

• ### SAP HANA, express edition makes HANA easier for non-SAP developers

Relaxed RAM and licensing requirements and the ability to run on local machines could help popularize the HANA in-memory platform...

• ### SAP futurists name five future technology trends to plan for now

Three SAP futurists explain what future technology trends in augmented reality, blockchain, AI, robotics, and contingent labor ...

• ### Abakus acquisition beefs up SAP Hybris marketing portfolio

SAP acquires Abakus marketing measurement software for SAP Hybris marketing suite; openSAP adds new courses for S/4HANA, data ...

## SearchSQLServer

• ### Options for scaling out SQL Server applications to boost workloads

Scaling out a database to meet the needs of a heavy processing workload can be a challenge. Here are details on the SQL Server ...

• ### Four trends that will impact SQL Server DBAs in 2017

Flash storage adoption, cloud computing's growth, Linux's increased importance and broader big data integration are a few trends ...

• ### DATEADD and DATEDIFF SQL functions for datetime values

DATEADD and DATEDIFF SQL functions allow you to easily perform calculations, like adding a time interval from a datetime value. ...

## TheServerSide

• ### Is JSON and XML your REST performance bottleneck?

Learn how ASCII encoding formats like JSON and REST can adversely impact server application performance compared with emerging ...

• ### Making multi-cloud deployment a reality at Netflix with Spinnaker

Learn how Netflix leveraged automation and Spinnaker to perform 4,000 multi-cloud deployments per day.

• ### The benefits of Java microservices in a Docker and DevOps world

To seasoned developers, microservices may sound like SOA by another name. But Java microservices apps delivered via Docker ...

## SearchDataCenter

• ### Converged infrastructure drop-off doesn't mean data center death

Traditional converged infrastructure has been supplanted by hyper-converged infrastructure and cloud computing, but it remains a ...

• ### New options to evolve your data backup and recovery plan

The server backup market first evolved to protect VMs, but now it's undergoing another transformation. Find out how it's evolved ...

• ### What should my dimensions be for a data center building design?

Don't get hung up on data center dimensions in the design phase. Focus on length-to-width ratios to get the most out of data ...

## SearchContentManagement

• ### Why SharePoint Framework could benefit business, not just developers

SharePoint Framework heralds a new, mobile-friendly, low-code era for Microsoft, which may give some organizations without .NET ...

• ### Using Microsoft MyAnalytics to improve workers' time management

Microsoft MyAnalytics has been hailed as the next great thing for analyzing worker productivity. But how can employees be assured...

• ### Is the Drupal content management system right for your business?

The open source Drupal content management system offers users responsive design and WYSIWYG content and web development tools, as...

## SearchFinancialApplications

• ### ADP acquires performance coaching and employee engagement software

The Marcus Buckingham Company's cloud-based performance management and employee engagement software is set to be integrated into ...

• ### Six keys to creating strong data-security measures

The rush to embrace digital technologies can put organizations at extreme risk. Here are six foundations for creating an ...

• ### Group-chat software sees explosive growth and intense competition

Microsoft Teams and Workplace by Facebook are facing off against rivals such as HipChat and Slack in a high-stakes competition ...

Close