在数据库中存储Linux时间戳通常有两种方法:作为整数(通常是秒或毫秒)或作为日期/时间数据类型。以下是两种常见的数据库(MySQL和PostgreSQL)中存储Linux时间戳的方法:
1. MySQL
在MySQL中,可以使用INT
或BIGINT
数据类型存储Linux时间戳。通常,我们使用BIGINT
来存储毫秒级的时间戳,以支持更高的精度。
创建表时,可以将时间戳字段定义为BIGINT
:
CREATE TABLE example (
id INT AUTO_INCREMENT PRIMARY KEY,
timestamp BIGINT
);
插入数据时,可以将Linux时间戳直接插入到该字段:
INSERT INTO example (timestamp) VALUES (UNIX_TIMESTAMP());
查询数据时,可以使用FROM_UNIXTIME()
函数将时间戳转换为可读的日期/时间格式:
SELECT FROM_UNIXTIME(timestamp) FROM example;
2. PostgreSQL
在PostgreSQL中,可以使用INTEGER
或BIGINT
数据类型存储Linux时间戳。与MySQL类似,我们通常使用BIGINT
来存储毫秒级的时间戳。
创建表时,可以将时间戳字段定义为BIGINT
:
CREATE TABLE example (
id SERIAL PRIMARY KEY,
timestamp BIGINT
);
插入数据时,可以将Linux时间戳直接插入到该字段:
INSERT INTO example (timestamp) VALUES (EXTRACT(EPOCH FROM NOW()) * 1000);
查询数据时,可以使用TO_TIMESTAMP()
函数将时间戳转换为可读的日期/时间格式:
SELECT TO_TIMESTAMP(timestamp / 1000) FROM example;
注意,这里我们将毫秒级时间戳除以1000,因为TO_TIMESTAMP()
函数默认接受秒级时间戳。