SQLite3学习笔记3:UTC和CST 时区偏差问题

1. 校准 Ubuntu 系统时间 / 时区

若系统时间本身和实际时间对不上,执行以下命令校准需同理校准时区 / 同步 NTP 时间):

bash 复制代码
# 1. 设置时区为上海(嵌入式设备常用时区)
sudo timedatectl set-timezone Asia/Shanghai

# 2. 安装时间同步工具(Ubuntu)
sudo apt install ntpdate -y

# 3. 同步网络时间(嵌入式设备可对接NTP服务器,无网络则手动设置)
sudo ntpdate pool.ntp.org

# 验证时间是否正确
date

2. 解决时间戳差 8 小时的问题

SQLite3 的CURRENT_TIMESTAMP默认生成的是UTC 时间(世界协调时间) ,而 Ubuntu 系统显示的是CST 时间(中国标准时间,UTC+8),所以数据库中记录的时间会比本地时间少 8 小时。

  • 数据库时间:2026-01-26 10:15:46(UTC)
  • 本地时间:2026-01-26 18:15:46(CST = UTC+8)
方案 1:查询时转换时区

核心逻辑:原始数据存 UTC(国际标准,便于跨时区设备溯源),查询时转换为 CST(UTC+8)。

sql 复制代码
// 原查询语句
SELECT * FROM device_params;

// 新查询语句(转换为CST时间)
SELECT id, param_name, param_value, datetime(update_ts, '+8 hours') AS update_ts_cst FROM device_params;

结果如下:

sql 复制代码
// UTC
1|temp|26.0|2026-01-26 10:15:46
2|humidity|60.2|2026-01-26 10:15:46

// CST
1|temp|26.0|2026-01-26 18:15:46
2|humidity|60.2|2026-01-26 18:15:46
方案 2:插入 / 更新时直接存 CST 时间

核心逻辑 :插入 / 更新时显式指定时区偏移,让update_ts直接存储 CST 时间 ------ 适合仅在国内使用、无需跨时区的嵌入式设备。

操作步骤(修改 INSERT/UPDATE 语句)
  1. 插入数据时直接存 CST
sql 复制代码
// 原插入语句(存UTC)
INSERT INTO device_params (param_name, param_value) VALUES ('temp', 26.5), ('humidity', 61.0);
   
// 新插入语句(存CST,显式+8小时)
INSERT INTO device_params (param_name, param_value, update_ts) VALUES ('temp', 26.5, datetime(CURRENT_TIMESTAMP, '+8 hours')), ('humidity', 61.0, datetime(CURRENT_TIMESTAMP, '+8 hours'));

结果如下:

sql 复制代码
// UTC
3|temp|26.5|2026-01-26 11:03:55
4|humidity|61.0|2026-01-26 11:03:55

// CST
5|temp|26.5|2026-01-26 19:04:16
6|humidity|61.0|2026-01-26 19:04:16
  1. 更新数据时同步存 CST
sql 复制代码
// 原更新语句(存UTC)
UPDATE device_params SET param_value = 27.0, update_ts = CURRENT_TIMESTAMP WHERE param_name = 'temp';
   
// 新更新语句(存CST)
UPDATE device_params SET param_value = 27.0, update_ts = datetime(CURRENT_TIMESTAMP, '+8 hours') WHERE param_name = 'temp';

结果如下:

sql 复制代码
// UTC
1|temp|27.0|2026-01-26 11:14:13
3|temp|27.0|2026-01-26 11:14:13
5|temp|27.0|2026-01-26 11:14:13

// CST
1|temp|27.0|2026-01-26 19:14:18
3|temp|27.0|2026-01-26 19:14:18
5|temp|27.0|2026-01-26 19:14:18
相关推荐
盐水冰12 小时前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
Hello小赵12 小时前
视频压缩编码学习(一)—— 基础知识大集合
学习
左左右右左右摇晃12 小时前
计算机网络笔记整理
笔记·计算机网络
不吃西红柿的8512 小时前
[职场] 内容运营求职简历范文 #笔记#职场发展
笔记·职场和发展·内容运营
似水明俊德13 小时前
02-C#.Net-反射-学习笔记
开发语言·笔记·学习·c#·.net
智者知已应修善业13 小时前
【51单片机独立按键控制数码管移动反向,2片74CH573/74CH273段和位,按键按下保持原状态】2023-3-25
经验分享·笔记·单片机·嵌入式硬件·算法·51单片机
adore.96813 小时前
3.18 复试学习
学习
C羊驼13 小时前
C语言:两天打鱼,三天晒网
c语言·经验分享·笔记·算法·青少年编程
留白_14 小时前
MySQL学习(9)——索引
学习
sheeta199814 小时前
苍穹外卖Day04笔记
笔记