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

MySQL NOW()에서 레코드 선택 -1일?

<시간/>

NOW()-1 Day에서 레코드를 가져오려면 다음 구문을 사용할 수 있습니다. -

select *from yourTableName where yourColumnName >=now()-interval 1 day;

위의 구문을 이해하기 위해 먼저 테이블을 생성해 보겠습니다. 테이블 생성 쿼리입니다.

mysql> create table GetRecordsFromNow
   −> (
   −> YourDateTime datetime
   −> );
Query OK, 0 rows affected (1.76 sec)

이제 필드에 일부 날짜를 삽입하십시오. 레코드를 삽입하는 쿼리는 다음과 같습니다 -

mysql> insert into GetRecordsFromNow values(date_add(now(),interval 3 day));
Query OK, 1 row affected (0.28 sec)

mysql> insert into GetRecordsFromNow values(date_add(now(),interval -1 day));
Query OK, 1 row affected (0.11 sec)

mysql> insert into GetRecordsFromNow values(date_add(now(),interval -2 day));
Query OK, 1 row affected (0.14 sec)

mysql> insert into GetRecordsFromNow values(date_add(now(),interval -3 day));
Query OK, 1 row affected (0.09 sec)

mysql> insert into GetRecordsFromNow values(date_add(now(),interval -1 day));
Query OK, 1 row affected (0.08 sec)

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

mysql> select *from GetRecordsFromNow;

다음은 출력입니다 -

+---------------------+
| YourDateTime        |
+---------------------+
| 2018-12-07 22:30:18 |
| 2018-12-03 22:30:31 |
| 2018-12-02 22:30:41 |
| 2018-12-01 22:30:56 |
| 2018-12-03 22:31:04 |
+---------------------+
5 rows in set (0.00 sec)

다음은 now() -1일 −

의 레코드를 표시하는 쿼리입니다.
mysql> select *from GetRecordsFromNow where YourDateTime >= now()-interval 1 day;

다음은 출력입니다 -

+---------------------+
| YourDateTime        |
+---------------------+
| 2018-12-07 22:30:18 |
+---------------------+
1 row in set (0.04 sec)