sql server中字符串类型的日期如何比较大小

SQL Server 计算两个时间相差

案例:计算 标准结束时间 和 实际结束时间 之间的秒数差,并根据这个差值判断是否超时。

假设 test 表中有以下数据:

标准结束时间 实际结束时间
2024-10-12 10:00:00 2024-10-12 10:30:00
2024-10-12 11:00:00 2024-10-12 10:55:00
2024-10-12 12:00:00 2024-10-12 12:00:00
sql 复制代码
SELECT 
    CASE 
        WHEN DATEDIFF(SECOND, CAST(标准结束时间 AS DATETIME), CAST(实际结束时间 AS DATETIME)) > 0 
        THEN 1
        ELSE 0
    END AS '是否超时',
    DATEDIFF(SECOND, CAST(标准结束时间 AS DATETIME), CAST(实际结束时间 AS DATETIME)) AS '实际超时'
FROM test;
  • CASE 语句:根据 DATEDIFF 函数的结果来判断是否超时。
  • 如果 实际结束时间 晚于 标准结束时间,则 DATEDIFF 的结果会大于 0,此时返回 1 表示超时。
    否则返回 0 表示没有超时。
  • DATEDIFF(SECOND, ...):计算 标准结束时间 和 实际结束时间 之间的秒数差。

执行上述查询后,结果将是:

是否超时 实际超时
1 1800
0 -300
0 0

注意事项

  • 数据类型:确保 标准结束时间 和 实际结束时间 列的数据类型是 VARCHAR 或其他可以被转换为 DATETIME 类型的字符串格式。
  • 格式一致性:确保 标准结束时间 和 实际结束时间 的字符串格式与 CAST 函数兼容。常见的兼容格式包括 'yyyy-MM-dd HH:mm:ss'、'MM/dd/yyyy HH:mm:ss' 等。
相关推荐
风123456789~1 分钟前
【Oracle专栏】密码到期但在宽限期->修改密码
数据库·oracle
Pocker_Spades_A7 分钟前
DeepCore:大模型统一网关,Claude 免费体验与跨模型技术洞察
java·服务器·数据库
八饱粥15 分钟前
excel数据导入mysql数据库
数据库·mysql·excel
('-')18 分钟前
《从根上理解MySQL是怎样运行的》第二十四章笔记
数据库·笔记·mysql
CodeAmaz20 分钟前
MySQL 事务的实现原理详解
数据库·mysql·事务·隔离性
Hello.Reader21 分钟前
Flink SQL + Kafka 实时统计部门人数
sql·flink·kafka
♡喜欢做梦21 分钟前
MyBatis操作数据库(进阶):动态SQL
java·数据库·sql·java-ee·mybatis
copyer_xyf22 分钟前
SQL 语法速查手册:前端开发者的学习笔记
前端·数据库·sql
承缘丶23 分钟前
Excel字段清单转各类数据库建表语句的工具(开箱即用)
数据库·excel·excel转数据库建表语句
风123456789~2 小时前
【OceanBase专栏】脚本调用OB过程实验
数据库·oceanbase