TDengine 时间函数 DAYOFWEEK 用户手册

在这里插入图片描述

DAYOFWEEK 函数使用手册

函数描述

DAYOFWEEK 函数用于返回指定日期是一周中的第几天。该函数遵循标准的星期编号约定,返回值范围为 1-7,其中:

  • 1 = 星期日 (Sunday)
  • 2 = 星期一 (Monday)
  • 3 = 星期二 (Tuesday)
  • 4 = 星期三 (Wednesday)
  • 5 = 星期四 (Thursday)
  • 6 = 星期五 (Friday)
  • 7 = 星期六 (Saturday)

语法

DAYOFWEEK(date_expression)

参数说明

  • date_expression: 日期表达式,支持以下类型:
    • TIMESTAMP 类型的时间戳
    • BIGINT 类型的 Unix 时间戳(秒或毫秒)
    • VARCHAR/NCHAR 类型的日期字符串
    • NULL 值

返回值

  • 返回类型BIGINT
  • 返回值范围:1-7(对应星期日到星期六)
  • 如果输入为 NULL,则返回 NULL

使用示例

1. 使用 TIMESTAMP 类型

-- 查询当前时间是星期几
SELECT DAYOFWEEK(NOW()) AS day_of_week;-- 查询指定时间戳是星期几
SELECT DAYOFWEEK('2024-01-15 10:30:00') AS day_of_week;
-- 结果: 2 (星期一)

2. 使用 Unix 时间戳

-- 使用秒级时间戳 (2024-01-15 对应的时间戳)
SELECT DAYOFWEEK(1705315800) AS day_of_week;
-- 结果: 4 (星期三)-- 使用毫秒级时间戳  
SELECT DAYOFWEEK(1705315800000) AS day_of_week;
-- 结果: 4 (星期三)

3. 使用日期字符串

-- ISO 格式日期字符串
SELECT DAYOFWEEK('2024-01-15') AS day_of_week;
-- 结果: 2 (星期一)-- 带时间的日期字符串
SELECT DAYOFWEEK('2024-12-25 12:00:00') AS day_of_week;
-- 结果: 4 (星期三,圣诞节)

4. 在表查询中使用

-- 假设有一个订单表 orders,包含 order_time 字段
SELECT order_id,order_time,DAYOFWEEK(order_time) AS order_day,CASE DAYOFWEEK(order_time)WHEN 1 THEN '星期日'WHEN 2 THEN '星期一'WHEN 3 THEN '星期二'WHEN 4 THEN '星期三'WHEN 5 THEN '星期四'WHEN 6 THEN '星期五'WHEN 7 THEN '星期六'END AS day_name
FROM orders
WHERE order_time >= '2024-01-01';

5. 统计分析示例

-- 统计每个工作日的订单数量
SELECT DAYOFWEEK(order_time) AS day_of_week,COUNT(*) AS order_count
FROM orders
WHERE order_time >= '2024-01-01'
GROUP BY DAYOFWEEK(order_time)
ORDER BY day_of_week;-- 筛选周末的数据
SELECT *
FROM orders  
WHERE DAYOFWEEK(order_time) IN (1, 7)  -- 星期日和星期六
AND order_time >= '2024-01-01';

6. 处理 NULL 值

-- NULL 值处理
SELECT DAYOFWEEK(NULL) AS result;
-- 结果: NULL-- 过滤 NULL 值
SELECT DAYOFWEEK(order_time) AS day_of_week
FROM orders where order_time is not null;

时区注意事项

重要说明

使用 DAYOFWEEK 函数时需要特别注意时区问题,因为不同的时区可能会影响日期的计算结果:

  1. 数据库时区设置: 函数的结果可能受到数据库服务器时区设置的影响
  2. 客户端时区: 客户端和服务器时区不一致时可能导致结果偏差
  3. UTC 转换: Unix 时间戳通常基于 UTC,在转换为本地时间时需要考虑时区偏移

时区相关示例

-- 显示当前时区设置
SELECT TIMEZONE();-- 在不同时区下同一时间戳可能返回不同的星期几
-- 例如:UTC 时间 2024-01-01 00:30:00 (星期一)
-- 在 UTC+8 时区显示为 2024-01-01 08:30:00 (星期一)
-- 在 UTC-5 时区显示为 2023-12-31 19:30:00 (星期日)SELECT '2024-01-01 00:30:00' AS utc_time,DAYOFWEEK('2024-01-01 00:30:00') AS day_utc;

建议

  1. 统一时区: 在应用中保持数据库和客户端时区的一致性
  2. 明确时区: 在处理跨时区数据时,明确指定时区或统一使用 UTC
  3. 测试验证: 在不同时区环境下测试函数返回结果的正确性

相关函数

  • WEEKDAY(): 返回星期几(0-6,Monday=0)
  • WEEK(): 返回一年中的第几周
  • WEEKOFYEAR(): 返回一年中的第几周(ISO 标准)
  • NOW(): 获取当前时间戳
  • TIMEZONE(): 获取当前时区设置

常见用途

  1. 业务分析: 分析不同工作日的业务数据分布
  2. 排班管理: 根据星期几安排工作计划
  3. 数据过滤: 筛选工作日或周末的数据
  4. 报表统计: 按星期维度进行数据统计和分析

关于 TDengine

TDengine 专为物联网IoT平台、工业大数据平台设计。其中,TDengine TSDB 是一款高性能、分布式的时序数据库(Time Series Database),同时它还带有内建的缓存、流式计算、数据订阅等系统功能;TDengine IDMP 是一款AI原生工业数据管理平台,它通过树状层次结构建立数据目录,对数据进行标准化、情景化,并通过 AI 提供实时分析、可视化、事件管理与报警等功能。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/95653.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/95653.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【STM32】贪吃蛇 [阶段 3] 增强模块结构(架构优化)

这篇博客是 承接:【项目思维】贪吃蛇(嵌入式进阶方向)中 聚焦于 🧱 阶段 3:增强模块结构(架构优化) 中的 菜单系统(Menu System),这部分的结构优化可以学到的…

江协科技STM32学习笔记补充之004

STM32 ISP 一键下载电路(按功能、逻辑与时序拆解)

数据库小册(1)

1. 关系型数据库主要考点关系型数据库:架构索引锁语法理论规范2. 如何设计一个关系型数据库设计即模块划分。数据库最主要的功能是存储我们的数据,所以需要一个存储的文件系统。我们要把涉及到的物流数据提供逻辑的形式给组织和表示出来,这是…

记录收入最高的一次私活 选号网,需要大量卖号的人可能需要,比如游戏脚本批量跑的号

选号网管理后台(上传游戏信息、账号信息、 查看记录) http://124.223.214.5:180/admin1 选号网客户端(PC/H5页面 给客户筛选商品用) http://124.223.214.5:181/ 该在线地址仅供低频率测试,正式使用需要另外部署。 功能不满足可以联系开发者定制 一、项目的由来 …

热烈庆祝“中国抗战胜利80周年”,织信低代码助力国之重器砥砺前行!

“从保家卫国到科技强军,织信低代码平台为军工企业数字化转型注入新动能。”80年后的今天,国人记忆从未褪色。2025年9月3日,正值中国抗战胜利80周年阅兵之际,我国国防军工力量在经历长期的艰苦奋斗后,现今终于迎来了曙…

PostgreSQL与SQL Server:B树索引差异及去重的优势

PostgreSQL与SQL Server:B树索引差异及去重的优势 在优化查询性能方面,索引是数据库工程师可使用的最强大工具之一。PostgreSQL和Microsoft SQL Server(或Azure SQL)都将B树索引用作其默认索引结构,但每个系统实现、维…

【微实验】使用MATLAB制作一张赛博古琴?

当一个理工音乐人没钱去买古琴,我直接用代码画一个古琴!目录 零、总脚本: 一、核心功能:交互模块拆解 二、核心价值 一、初始化脚本:参数配置与启动界面 ①废话不说,直接上代码 ②代码模块拆解与详细解…

毕业项目推荐:67-基于yolov8/yolov5/yolo11的大棚黄瓜检测识别系统(Python+卷积神经网络)

文章目录 项目介绍大全(可点击查看,不定时更新中)概要一、整体资源介绍技术要点功能展示:功能1 支持单张图片识别功能2 支持遍历文件夹识别功能3 支持识别视频文件功能4 支持摄像头识别功能5 支持结果文件导出(xls格式…

无人机小尺寸RFSOC ZU47DR板卡

整板尺寸:120*120mmFPGA: XCZU47DR-2FFVE1156I;DDR:PS侧8GB 2400Mhz*64bit / PL侧 4GB 2400Mhz*32bit;2路(QSP0QSPI1)/单片512Mb、共计1Gb;千兆以太网:1路(PS侧);主要接口资源如下&a…

LangGraph(一):入门从0到1(零基础)

文章目录LangGraph入门从0到10️⃣ 安装 & 确认环境1️⃣ 把 LangGraph 想象成「自动化的做菜流水线」2️⃣ 最小可运行例子:一句话复读机3️⃣ 加一个小节点:把用户输入变大写4️⃣ 条件边:如果用户说 quit 就结束,否则复读5…

学习数据结构(16)快速排序

快速排序的基本思想:快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法,其基本思想为:任取待排序元素序列中的某元素作为基准值,按照该基准值将待排序集合分割成两子序列,左子序列中所有元素均小于基准值&am…

uni-app iOS 上架常见问题与解决方案,实战经验全解析

uni-app 让开发者能够“一套代码,多端运行”,极大降低了开发成本。 但当应用进入 iOS 上架阶段 时,不少团队发现流程并没有想象中那么顺利:证书问题、打包失败、上传出错、审核被拒……这些都可能让项目卡壳。 本文结合实际案例&a…

洗衣机的智能升级集成方案WT2606B屏幕驱动+AI语音控制

2025,洗衣机市场正从功能满足转向体验升级,企业正面临哪些转型难点?一文为您解读洗衣机行业智能化升级之路。传统洗衣机就像是一个"沉默的工人",只能通过简单的LED指示灯告诉你它在工作,却无法让你真正了解它在干嘛。用…

机器学习进阶,梯度提升机(GBM)与XGBoost

梯度提升机(Gradient Boosting Machine, GBM),特别是其现代高效实现——XGBoost。这是继随机森林后自然进阶的方向,也是当前结构化数据竞赛和工业界应用中最强大、最受欢迎的算法之一。为什么推荐XGBoost? 与随机森林互…

【ARMv7】开篇:掌握ARMv7架构Soc开发技能

本专栏,开始与大家共同总结使用ARMv7系列CPU的Soc开发技能。大概汇总了一下,后面再逐步完善下面的思维导图。简单说说:与通用的ARMv7-A/R相比,以STM32F为代表的ARMv7-M架构有以下关键区别和重点:无MMU,有MP…

【学术会议论文投稿】JavaScript在数据可视化领域的探索与实践

【ACM出版 | EI快检索 | 高录用】2024年智能医疗与可穿戴智能设备国际学术会议(SHWID 2024)_艾思科蓝_学术一站式服务平台 更多学术会议请看 学术会议-学术交流征稿-学术会议在线-艾思科蓝 目录 引言 JavaScript可视化库概览 D3.js基础入门 1. 引入…

CSS基础学习步骤

好的,这是一份为零基础初学者量身定制的 **CSS 学习基础详细步骤**。我们将从最根本的概念开始,通过一步一步的实践,带你稳稳地入门。 第一步:建立核心认知 - CSS 是做什么的? 1. 理解角色: HTML&…

MTK Linux DRM分析(三十七)- MTK phy-mtk-hdmi.c 和 phy-mtk-hdmi-mt8173.c

一、简介 HDMI PHY驱动 HDMI 的物理层接口主要就是 HDMI Type-A 接口(19 pin),除此之外还有 Type-B、Type-C(Mini HDMI)、Type-D(Micro HDMI)、Type-E(车载专用)。 1. HDMI Type-A(常见 19-pin 标准接口) HDMI Type-A Connector Pinout ========================…

【人工智能学习之MMdeploy部署踩坑总结】

【人工智能学习之MMdeploy部署踩坑总结】报错1:TRTNet: device must be a GPU!报错2:Failed to create Net backend: tensorrt报错3:Failed to load library libonnxruntime_providers_shared.so1. 确认库文件是否存在2. 重新安装 ONNX Runti…

力扣516 代码随想录Day16 第一题

找二叉树左下角的值class Solution { public:int maxd0;int result;void traversal(TreeNode* root,int depth){if(root->leftNULL&&root->rightNULL){if(depth>maxd){maxddepth;resultroot->val;}}if(root->left){depth;traversal(root->left,depth…