Creating Random Dates in ColdFusion: RandDateRange( dtFrom, dtTo )

Posted July 7, 2006 at 3:08 PM by Ben Nadel

Tags: ColdFusion

Someone was just asking me how to create a random date in ColdFusion. More specifically, how to create a random date between two dates. The solutions for this is quite simple once you understand it. I have created a method named RandDateRange(). This method functions similar to RandRange( intFrom, intTo ) and actually uses that method under the hood. If you abstract generating a random date between two given dates, it comes down to picking a random point in time. We can create this random point by adding a random time span to the "From Date", making sure, of course, that this random time span does not give us a date past the desired "To Date".

The beauty of time spans in ColdFusion is that they can be represented as a single floating point number. This puts us in the perfect position to use RandRange() to create random time spans. To make sure that we do not create too large a timespan, our bottom range parameter will be zero and our top range parameter will be the difference in seconds between the two out lier dates. Therefore, if we get a random second value and add it to the "From Date", we know we can never go past the "To Date."

  • <cffunction name="RandDateRange" access="public" returntype="date" output="false"
  • hint="This returns a random date between the two given dates (inclusive).">

  • <!--- Define arguments. --->
  • <cfargument name="FromDate" type="date" required="true" />
  • <cfargument name="ToDate" type="date" required="true" />

  • <cfscript>

  • // Define the local scope.
  • var LOCAL = StructNew();

  • // Get the difference in seconds between the two dates.
  • LOCAL.TimeDifference = DateDiff(
  • "s",
  • ARGUMENTS.FromDate,
  • ARGUMENTS.ToDate
  • );

  • // Create a random time increment based on the second difference.
  • // The time span object is a representation of time-length in
  • // terms of a single floating-point number.
  • LOCAL.TimeIncrement = CreateTimeSpan(
  • 0, // Days
  • 0, // Hours
  • 0, // Minutes
  • RandRange( // Seconds
  • // Our smallest possible time increment.
  • 0,

  • // Our largest possible time increment that will not
  • // put us past the ToDate.
  • LOCAL.TimeDifference
  • )
  • );

  • // Get a new random date based on the FromDate and the random
  • // time span.
  • LOCAL.RandomDate = (ARGUMENTS.FromDate + LOCAL.TimeIncrement);

  • // This random date now is formatted like a TimeSpan object,
  • // meaning that it is in the form of one floating point number.
  • return( LOCAL.RandomDate );

  • </cfscript>
  • </cffunction>

Now to test it out. For the from and to dates, let's pick Now and one month from Now.

From: 2006-07-07
To: 2006-08-07

Now, get a random date between those to:

Random: 38931.4080093

As you can see above, the random date is in Time Span format (represented as a single floating point number). In order to fix that, all we have to do is run a date format on it. Now, keep in mind that ColdFusion still treats that as a valid date. You only need to change the formatting on it for display. You can add, diff, subtract all you want on the server side and its all good.

Formatted: 2006-08-02




Reader Comments

There are no comments posted for this web log entry.

Post A Comment

Comment Etiquette: Please do not post spam. Please keep the comments on-topic. Please do not post unrelated questions or large chunks of code. And, above all, please be nice to each other - we're trying to have a good conversation here.

Please review the following issues:

Author Name:


Author Email:

Author Website:

Comment:

Supported HTML tags for formatting: <strong>bold</strong>   <em>italic</em>   <code>code</code>







  • Help Wanted - Find Your Next ColdFusion Job
Ben Nadel's Company - Epicenter Consulting Recent Blog Comments
May 24, 2013 at 5:39 PM
Ask Ben: Manually Enforcing Basic HTTP Authorization In ColdFusion
@Adam Oops! My mistake! I hadn't gotten that far in my testing - I'm still baby stepping my way through the process. ... read »
May 24, 2013 at 5:13 PM
Ask Ben: Manually Enforcing Basic HTTP Authorization In ColdFusion
Hi Jason, Thanks for checking up on that, but I still stand firm on my position. :) There are actually two listLast()'s in use, and you're right that the one using a space as a delimiter is fine. ... read »
May 24, 2013 at 4:45 PM
Ask Ben: Manually Enforcing Basic HTTP Authorization In ColdFusion
@Ben I have been lurking your site for quite some time, and haven't stepped up to comment until today. Thanks for all the great info - keep it up! @Adam I believe you are mistaken... as the commen ... read »
May 24, 2013 at 11:21 AM
Strange Interaction Between DeserializeJson(), ArrayContains(), And Database Values In ColdFusion
@WebManWalking, Ha ha, let's us never speak of justifying "##" notation again :P ... read »
May 24, 2013 at 11:18 AM
Strange Interaction Between DeserializeJson(), ArrayContains(), And Database Values In ColdFusion
@Ben, Ah, so it was indeed how I vaguely remembered it to be: A direct assignment value = users.id[ i ] causes value to retain the sticky datatype of the query column. Although unnecessary in ... read »
May 24, 2013 at 9:11 AM
Preventing Links In Standalone iPhone Applications From Opening In Mobile Safari
@Brandon, Hi, No, I haven't been able to do that. I have just kept it as it is. ... read »
May 23, 2013 at 9:52 PM
Preventing Links In Standalone iPhone Applications From Opening In Mobile Safari
@Muhmmadibn Did you figure out a solution to launching PDFs? I am running into the same issues myself. There is no way to close the PDF or go back once you launch it. Thanks in advance! ... read »
May 23, 2013 at 6:06 PM
The Girl Who Broke My Heart, And Made Me A Better Person
Good day,ladies and gentle men, my name is Dr AMADI the great spell caster in Africa, i have help so many people for different kind of problems,who say there is no solution to problems on earth, that ... read »
InVision App - Prototyping Made Beautiful With Prototyping Tools