-1

if I want to retrieve the date and time from db and show it in format

"2 mins ago, just now, or 6 months ago" kinda etc.,

how can i do it.. :)

Can any one suggest me how to do this please,

sangram parmar
  • 8,462
  • 2
  • 23
  • 47
Guruprasad J Rao
  • 29,410
  • 14
  • 101
  • 200

2 Answers2

2
string gettime(DateTime updatedat)
{
     string toren = "A moment earlier";
     TimeSpan ts = DateTime.Now - updatedat;
     if (ts.TotalSeconds<60)
     {
          toren = ts.TotalSeconds.ToString() + " seconds ago";
     }
     else if (ts.TotalMinutes < 60)
     {
          toren = ts.TotalMinutes.ToString() + " minutes ago";
     }
     else if (ts.TotalHours < 24)
     {
          toren = ts.TotalHours.ToString() + " hours ago";
     }
     else if (ts.TotalDays < 30)
     {
          toren = ts.TotalDays.ToString() + " days ago";
     }
     else 
     {
          double month = ts.TotalDays / 30;
          if (month<13)
          {
               toren = month.ToString() + " months ago";
          }
          else
          {
               double year = month / 12;
               toren = year.ToString() + " years ago";
          }
     }
     return toren;
}

Change/Optimize it according to your need.

Ratna
  • 2,289
  • 3
  • 26
  • 50
1

Quoted answer from here:

const int SECOND = 1;
const int MINUTE = 60 * SECOND;
const int HOUR = 60 * MINUTE;
const int DAY = 24 * HOUR;
const int MONTH = 30 * DAY;

if (delta < 0)
{
  return "not yet";
}
if (delta < 1 * MINUTE)
{
  return ts.Seconds == 1 ? "one second ago" : ts.Seconds + " seconds ago";
}
if (delta < 2 * MINUTE)
{
  return "a minute ago";
}
if (delta < 45 * MINUTE)
{
  return ts.Minutes + " minutes ago";
}
if (delta < 90 * MINUTE)
{
  return "an hour ago";
}
if (delta < 24 * HOUR)
{
  return ts.Hours + " hours ago";
}
if (delta < 48 * HOUR)
{
  return "yesterday";
}
if (delta < 30 * DAY)
{
  return ts.Days + " days ago";
}
if (delta < 12 * MONTH)
{
  int months = Convert.ToInt32(Math.Floor((double)ts.Days / 30));
  return months <= 1 ? "one month ago" : months + " months ago";
}
else
{
  int years = Convert.ToInt32(Math.Floor((double)ts.Days / 365));
  return years <= 1 ? "one year ago" : years + " years ago";
}

And yes, I do quote. Because this answer meets exactly what the PO wants. :)

EDIT: Question by PO: One more thing.. What if I am retrieving the date and time field from database. How can I imply this code?

Without knowing your structure or code, it would look something like this:

var cmd = new SqlCommand(yourConnection);
cmd.CommandText = "SELECT yourDateColumn FROM yourTable";
using (var sr = cmd.ExecuteReader)
{
  if (sr.Read)
  {
    var yourDateTime = sr.GetDateTime(0);
  }
}
Community
  • 1
  • 1
Fabian Bigler
  • 10,403
  • 6
  • 47
  • 70