MySQL
 Computer >> コンピューター >  >> プログラミング >> MySQL

MySQLはtimediff出力を日、時、分、秒の形式に変換しますか?


MySQLがtimediff出力を日、時、分、秒の形式に変換することを理解するには、MySQLのCONCAT()を使用する必要があります。

テーブルを作成しましょう。テーブルを作成するためのクエリは次のとおりです。

mysql> create table convertTimeDifferenceDemo
   -> (
   -> Id int NOT NULL AUTO_INCREMENT,
   -> StartDate datetime,
   -> EndDate datetime,
   -> PRIMARY KEY(Id)
   -> );
Query OK, 0 rows affected (0.68 sec)

挿入コマンドを使用して、テーブルにいくつかのレコードを挿入します。レコードを挿入するためのクエリは次のとおりです。

mysql> insert into convertTimeDifferenceDemo(StartDate,EndDate) values(date_add(now(),interval -3 hour),date_add(now(),interval 3 hour));
Query OK, 1 row affected (0.41 sec)
mysql> insert into convertTimeDifferenceDemo(StartDate,EndDate) values(date_add(now(),interval -2 hour),date_add(now(),interval 2 hour));
Query OK, 1 row affected (0.27 sec)
mysql> insert into convertTimeDifferenceDemo(StartDate,EndDate) values('2018-04-05 12:30:35','2018-05-17 14:30:50');
Query OK, 1 row affected (0.14 sec)
mysql> insert into convertTimeDifferenceDemo(StartDate,EndDate) values('2017-10-11 11:20:30','2017-12-17 15:21:55');
Query OK, 1 row affected (0.20 sec)

selectステートメントを使用して、テーブルのすべてのレコードを表示します。クエリは次のとおりです。

mysql> select *from convertTimeDifferenceDemo;

出力は次のとおりです。

+----+---------------------+---------------------+
| Id | StartDate           | EndDate             |
+----+---------------------+---------------------+
|  1 | 2019-01-28 20:55:33 | 2019-01-29 02:55:33 |
|  2 | 2019-01-28 21:57:42 | 2019-01-29 01:57:42 |
|  3 | 2018-04-05 12:30:35 | 2018-05-17 14:30:50 |
|  4 | 2017-10-11 11:20:30 | 2017-12-17 15:21:55 |
+----+---------------------+---------------------+
4 rows in set (0.00 sec)

これは、timediff出力を日、時、分、および秒の形式で取得するためのクエリです。

mysql> SELECT CONCAT(
   -> FLOOR(HOUR(TIMEDIFF(StartDate,EndDate)) / 24), ' DAYS ',
   -> MOD(HOUR(TIMEDIFF(StartDate,EndDate)), 24), ' HOURS ',
   -> MINUTE(TIMEDIFF(StartDate,EndDate)), ' MINUTES ') AS DESCRIPTION
   -> FROM convertTimeDifferenceDemo;

出力は次のとおりです。

+------------------------------+
| DESCRIPTION                  |
+------------------------------+
| 0 DAYS 6 HOURS 0 MINUTES     |
| 0 DAYS 4 HOURS 0 MINUTES     |
| 34 DAYS 22 HOURS 59 MINUTES  |
| 34 DAYS 22 HOURS 59 MINUTES  |
+------------------------------+
4 rows in set, 6 warnings (0.04 sec)

  1. PHP MySQLで日付形式(DBまたは出力)をdd / mm / yyyyに変更しますか?

    PHPの日付形式は、date()機能を使用して変更できます。構文は次のとおりです- date(d/m/Y,yourDateTimeVariable); PHPでは、strtodate()を使用して文字列を日付に変換します。日時のフォーマットに使用されるPHPコードは次のとおりです- $LogintDate = strtotime('2019-01-12'); echo date('d/m/Y', $LogintDate); コードのスナップショットは次のとおりです- 以下は出力です- 12/01/2019 あなたはdate_format()関数の助け

  2. PHP変数「11:00AM」をMySQL時間形式に変換しますか?

    DateTimeを使用して、PHP変数「11:00 AM:をMySQL時間形式に変換します。 PHPコードは次のとおりです- $phpTime = '11:00 AM'; echo('The PHP Time Format is ='); echo ($phpTime); $timeFormat = DateTime::createFromFormat( 'H:i A', $phpTime); $MySQLTimeFormat = $timeFormat->format( 'H:i:s'); echo ('