Friday, 10 August 2018

Convert Time Into Timestamp Or Timestamp Into Time In PHP

The easiest (and most reliable) way to store the time in a database table is with a timestamp. It is also the most convenient way of working out time scales as you don't have to do calculations in base 60. In MySQL this is accomplished by the UNIXTIME() function, which can be reversed by using another MySQL function called FROM_UNIXTIME().
However, you can sometimes be left with timestamps in your code and the task of trying to figure out what to do with them.
The first problem is trying to convert a timestamp into a date. So here is a PHP function that does this.
  1. function timestamp($t = null){
  2. if($t == null){
  3. $t = time();
  4. }
  5. return date('Y-m-d H:i:s', $t);
  6. }
And if you ever have a the opposite problem then here is a PHP function that converts a date string into a timestamp. At the moment the string needs to be in the format YYYY-MM-DD HH:MM:SS, which is what the previous function produced. This isn't too difficult to change, just alter the parameters and order of the explode(' ', $str).
  1. function convert_datetime($str) {
  2.  
  3. list($date, $time) = explode(' ', $str);
  4. list($year, $month, $day) = explode('-', $date);
  5. list($hour, $minute, $second) = explode(':', $time);
  6.  
  7. $timestamp = mktime($hour, $minute, $second, $month, $day, $year);
  8.  
  9. return $timestamp;
  10. }
Here is an example of the functions in use.
echo timestamp(convert_datetime('2008-05-10 20:56:00')). '  '. convert_datetime('2008-05-10 20:56:00') . ' 1210467360';

0 comments:

Post a Comment