news 2026/4/16 18:04:22

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SQLite3学习笔记3:UTC和CST 时区偏差问题

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

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

# 1. 设置时区为上海(嵌入式设备常用时区)sudotimedatectl set-timezone Asia/Shanghai# 2. 安装时间同步工具(Ubuntu)sudoaptinstallntpdate -y# 3. 同步网络时间(嵌入式设备可对接NTP服务器,无网络则手动设置)sudontpdate 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)。

// 原查询语句SELECT*FROMdevice_params;// 新查询语句(转换为CST时间)SELECTid,param_name,param_value,datetime(update_ts,'+8 hours')ASupdate_ts_cstFROMdevice_params;

结果如下:

// UTC1|temp|26.0|2026-01-2610:15:462|humidity|60.2|2026-01-2610:15:46// CST1|temp|26.0|2026-01-2618:15:462|humidity|60.2|2026-01-2618:15:46
方案 2:插入 / 更新时直接存 CST 时间

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

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

结果如下:

// UTC3|temp|26.5|2026-01-2611:03:554|humidity|61.0|2026-01-2611:03:55// CST5|temp|26.5|2026-01-2619:04:166|humidity|61.0|2026-01-2619:04:16
  1. 更新数据时同步存 CST
// 原更新语句(存UTC)UPDATEdevice_paramsSETparam_value=27.0,update_ts=CURRENT_TIMESTAMPWHEREparam_name='temp';// 新更新语句(存CST)UPDATEdevice_paramsSETparam_value=27.0,update_ts=datetime(CURRENT_TIMESTAMP,'+8 hours')WHEREparam_name='temp';

结果如下:

// UTC1|temp|27.0|2026-01-2611:14:133|temp|27.0|2026-01-2611:14:135|temp|27.0|2026-01-2611:14:13// CST1|temp|27.0|2026-01-2619:14:183|temp|27.0|2026-01-2619:14:185|temp|27.0|2026-01-2619:14:18
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 7:35:52

互联网产品使用UEDITOR的ELECTRON插件如何生成图片URL?

日期:2023年X月X日 角色:北京XX软件公司 全栈开发工程师(.NET Core Vue2) 项目背景:客户要求在后台管理系统的文章发布模块新增三大功能: Word粘贴功能:支持从Word复制内容粘贴到UEditor&…

作者头像 李华
网站建设 2026/4/16 7:35:20

智能金融预测破局指南:AI驱动的量化投资决策沙盘

智能金融预测破局指南:AI驱动的量化投资决策沙盘 【免费下载链接】Kronos Kronos: A Foundation Model for the Language of Financial Markets 项目地址: https://gitcode.com/GitHub_Trending/kronos14/Kronos 在瞬息万变的金融市场中,金融AI预…

作者头像 李华
网站建设 2026/4/15 11:52:36

黑苹果配置工具OpCore Simplify:从入门到精通的EFI创建指南

黑苹果配置工具OpCore Simplify:从入门到精通的EFI创建指南 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 黑苹果配置工具OpCore Simplif…

作者头像 李华
网站建设 2026/4/15 19:16:40

手把手教你学Simulink--电机电磁兼容与可靠性​场景示例:基于Simulink的电机机械共振抑制仿真

目录 手把手教你学Simulink 一、引言:为什么“电机一到某转速就抖得厉害”?——机械共振是隐形杀手! 二、机械共振机理:从控制指令到结构振动 典型双惯量系统模型 谐振频率计算 三、应用场景:工业伺服系统的高速高精控制 系统参数 控制需求 四、建模与实现步骤(…

作者头像 李华
网站建设 2026/4/16 7:35:41

OpCore Simplify:让黑苹果配置从3小时缩短到30分钟的智能工具

OpCore Simplify:让黑苹果配置从3小时缩短到30分钟的智能工具 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 当李明第三次尝试安装黑苹果…

作者头像 李华