MySQL中的时间戳(Timestamp)是一种数据类型,用于存储日期和时间值。它通常用于记录数据的创建时间或最后修改时间。时间戳的值是一个从1970年1月1日(UTC)开始的秒数。
MySQL中的时间戳类型主要有两种:
TIMESTAMP
:存储从1970年1月1日(UTC)开始的秒数,范围是1970-01-01 00:00:01 UTC到2038-01-19 03:14:07 UTC。DATETIME
:存储日期和时间,范围是1000-01-01 00:00:00到9999-12-31 23:59:59。时间戳常用于以下场景:
以下是一个简单的示例,展示如何在MySQL中创建一个包含时间戳字段的表,并插入和查询数据:
-- 创建表
CREATE TABLE example_table (
id INT AUTO_INCREMENT PRIMARY KEY,
name VARCHAR(255),
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
);
-- 插入数据
INSERT INTO example_table (name) VALUES ('Alice');
INSERT INTO example_table (name) VALUES ('Bob');
-- 查询数据
SELECT * FROM example_table;
原因:
ON UPDATE CURRENT_TIMESTAMP
。解决方法:
ON UPDATE CURRENT_TIMESTAMP
。ALTER TABLE example_table MODIFY COLUMN updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP;
解决方法:
FROM_UNIXTIME()
函数将时间戳转换为日期时间格式。SELECT FROM_UNIXTIME(created_at) AS readable_date FROM example_table;
通过以上信息,您应该能够更好地理解和应用MySQL中的时间戳。
领取专属 10元无门槛券
手把手带您无忧上云