【问题标题】:SQL date values converted to integers转换为整数的 SQL 日期值
【发布时间】:2013-06-27 14:18:51
【问题描述】:

好吧,我看不懂这个东西。

我的一个客户有一个旧的 Windows 应用程序(用于生成发票),它将日期值存储为整数。

问题是像'01.01.2002'(值类型:日期)这样表示的内容在SQL Server 2000 中确实存储为731217(列类型:整数)。

将日期值转换为整数是一种已知的方法吗(例如 - 我不知道 - 为了使日期差异计算更容易?)

顺便说一句,我必须将这些数据迁移到一个新的应用程序中,但是我搜索了很多关于它的内容,但我无法弄清楚用于应用这种转换的算法。

任何人都可以带来一些光明吗?

【问题讨论】:

    标签: sql-server date integer type-conversion


    【解决方案1】:

    它看起来像是自 0000 年 1 月 1 日以来的天数(尽管那一年并不真正存在)。

    无论如何,将日期作为参考,例如 2000 年 1 月 1 日,然后查看该日期的整数(例如 730121)。

    然后,您可以使用 DATEADD 函数将特定日期的整数与参考日期的整数与参考日期的天数之间的差值计算出来。

    DATEADD(day, *difference (eg 731217 - 730121)*, *reference date in proper SQLServer format*)
    

    如果您休息一天两天,您可以进行调整。

    【讨论】:

      猜你喜欢
      • 2020-04-04
      • 2023-03-19
      • 1970-01-01
      • 2019-11-21
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2021-08-17
      • 2018-10-16
      相关资源
      最近更新 更多