Bạn cần sử dụng TIME_FORMAT () để xóa giây khỏi trường thời gian. Cú pháp như sau:
SELECT TIME_FORMAT(yourColumnName1, "%H:%i") AS anyVariableName, TIME_FORMAT(yourColumnName2, "%H:%i") AS anyVariableName FROM yourTableName;
Để hiểu cú pháp trên, chúng ta hãy tạo một bảng. Truy vấn để tạo bảng như sau:
mysql> create table removeSecondsFromTime -> ( -> Id int NOT NULL AUTO_INCREMENT, -> StartTime time, -> EndTime time, -> PRIMARY KEY(Id) -> ); Query OK, 0 rows affected (0.71 sec)
Chèn một số bản ghi trong bảng bằng lệnh chèn. Truy vấn như sau:
mysql> insert into removeSecondsFromTime(StartTime,EndTime) values('10:20:45','11:21:40'); Query OK, 1 row affected (0.43 sec) mysql> insert into removeSecondsFromTime(StartTime,EndTime) values('12:30:55','13:20:21'); Query OK, 1 row affected (0.31 sec) mysql> insert into removeSecondsFromTime(StartTime,EndTime) values('14:40:57','15:55:02'); Query OK, 1 row affected (0.24 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 removeSecondsFromTime;
Sau đây là kết quả đầu ra;
+----+-----------+----------+ | Id | StartTime | EndTime | +----+-----------+----------+ | 1 | 10:20:45 | 11:21:40 | | 2 | 12:30:55 | 13:20:21 | | 3 | 14:40:57 | 15:55:02 | +----+-----------+----------+ 3 rows in set (0.00 sec)
Đây là truy vấn để xóa giây khỏi trường thời gian:
mysql> select TIME_FORMAT(StartTime, "%H:%i") as StartingTime, -> TIME_FORMAT(EndTime, "%H:%i") as EndingTime -> from removeSecondsFromTime;
Sau đây là kết quả đầu ra;
+--------------+------------+ | StartingTime | EndingTime | +--------------+------------+ | 10:20 | 11:21 | | 12:30 | 13:20 | | 14:40 | 15:55 | +--------------+------------+ 3 rows in set (0.00 sec)