Computer >> Máy Tính >  >> Lập trình >> MySQL

MySQL chuyển đổi đầu ra timediff sang định dạng ngày, giờ, phút, giây?

Để hiểu MySQL chuyển đổi đầu ra timediff sang định dạng ngày, giờ, phút và giây, bạn cần sử dụng CONCAT () từ MySQL.

Hãy để chúng tôi tạo một bảng. Truy vấn để tạo bảng như sau:

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)

Chèn một số bản ghi trong bảng bằng lệnh chèn. Truy vấn để chèn bản ghi như sau:

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)

Hiển thị tất cả các bản ghi từ bảng bằng cách sử dụng câu lệnh select. Truy vấn như sau:

mysql> select *from convertTimeDifferenceDemo;

Sau đây là kết quả:

+----+---------------------+---------------------+
| 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)

Đây là truy vấn để nhận đầu ra trung bình sang định dạng ngày, giờ, phút và giây:

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;

Sau đây là kết quả:

+------------------------------+
| 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)