Computer >> 컴퓨터 >  >> 프로그램 작성 >> MySQL

MySQL의 시간 필드에서 초를 제거하시겠습니까?

<시간/>

시간 필드에서 초를 제거하려면 TIME_FORMAT()을 사용해야 합니다. 구문은 다음과 같습니다.

SELECT TIME_FORMAT(yourColumnName1, "%H:%i") AS anyVariableName,
TIME_FORMAT(yourColumnName2, "%H:%i") AS anyVariableName
FROM yourTableName;

위의 구문을 이해하기 위해 테이블을 생성해 보겠습니다. 테이블 생성 쿼리는 다음과 같습니다.

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)

삽입 명령을 사용하여 테이블에 일부 레코드를 삽입하십시오. 쿼리는 다음과 같습니다.

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)

select 문을 사용하여 테이블의 모든 레코드를 표시합니다. 쿼리는 다음과 같습니다.

mysql> select *from removeSecondsFromTime;

다음은 출력입니다.

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

다음은 시간 필드에서 초를 제거하는 쿼리입니다.

mysql> select TIME_FORMAT(StartTime, "%H:%i") as StartingTime,
   -> TIME_FORMAT(EndTime, "%H:%i") as EndingTime
   -> from removeSecondsFromTime;

다음은 출력입니다.

+--------------+------------+
| StartingTime | EndingTime |
+--------------+------------+
| 10:20        | 11:21      |
| 12:30        | 13:20      |
| 14:40        | 15:55      |
+--------------+------------+
3 rows in set (0.00 sec)