如何在MySQL当前时间戳中选择10分钟内的所有记录?

您可以使用以下语法选择当前时间戳内10分钟之内的所有记录-

SELECT *FROM yourTableName
WHERE yourColumnName > = DATE_SUB(NOW(),INTERVAL 10 MINUTE);

为了理解上述语法,让我们创建一个表。创建表的查询如下-

create table users
   -> (
   -> Id int NOT NULL AUTO_INCREMENT,
   -> UserName varchar(20),
   -> UserLastseen datetime,
   -> PRIMARY KEY(Id)
   -> );

使用insert命令在表中插入一些记录。查询如下-

insert into users(UserName,UserLastseen) values('Larry','2019-01-15 02−45−00');

insert into users(UserName,UserLastseen) values('Sam',now());

insert into users(UserName,UserLastseen) values('Mike','2019-01-15 02−30−00');

insert into users(UserName,UserLastseen) values('Bob','2019-01-15 15−02−00');

insert into users(UserName,UserLastseen) values('David','2019-01-15 14−55−00');

使用select语句显示表中的所有记录。查询如下-

select *from users;

以下是输出-

+----+----------+---------------------+
| Id | UserName | UserLastseen        |
+----+----------+---------------------+
|  1 | Larry    | 2019-01-15 02−45−00 |
|  2 | Sam | 2019-01-15 15−01−52 |
|  3 | Mike | 2019-01-15 02−30−00 |
|  4 | Bob | 2019-01-15 15−02−00 |
|  5 | David | 2019-01-15 14−55−00 |
+----+----------+---------------------+
5 rows in set (0.00 sec)

这是查询以选择当前时间戳内10分钟之内的所有记录-

select *from users
   -> where UserLastseen> = date_sub(now(),interval 10 minute);

以下是输出-

+----+----------+---------------------+
| Id | UserName | UserLastseen        |
+----+----------+---------------------+
|  2 | Sam      | 2019-01-15 15−01−52 |
|  4 | Bob      | 2019-01-15 15−02−00 |
|  5 | David    | 2019-01-15 14−55−00 |
+----+----------+---------------------+
3 rows in set (0.00 sec)