求两个日期之间的天数

image.png

在jdbc的库可以查询在hana就报错

SQL yzmfKZXQ1464691 发布于 2023-8-30 15:03
1min目标场景问卷 立即参与
回答问题
悬赏:0 F币 + 添加悬赏
提示:增加悬赏、完善问题、追问等操作,可使您的问题被置顶,并向所有关注者发送通知
共1回答
最佳回答
0
snrtuemcLv8专家互助
发布于2023-8-30 15:05(编辑于 2023-8-30 15:06)

hana写法是

SELECT DATEDIFF('2020-01-01', '2019-12-31', 'DAY') AS diff;

===================================

可以的哈,直接帆软中求吧

DATESUBDATE(date1,date2,op):返回两个日期之间的时间差。

op表示返回的时间单位:"s",以秒为单位。"m",以分钟为单位。"h",以小时为单位。"d",以天为单位。"w",以周为单位。

示例:

DATESUBDATE("2008-08-08","2008-06-06","h")等于1512。

===========

DATEDIF(start_date,end_date,unit,method):返回两个指定日期间的天数、月数或年数。

Start_date:代表所指定时间段的初始日期。

End_date:代表所指定时间段的终止日期。

Unit:函数返回信息的类型。

method:可选参数,默认返回日期差值的绝对值。

若unit="Y",则DATEDIF返回指定时间段的年差数。

若unit="M",则DATEDIF返回指定时间段的月差数。

若unit="D",则DATEDIF返回指定时间段的日差数。

若unit="MD",则DATEDIF忽略年和月,返回指定时间段的日差数。

若unit="YM",则DATEDIF忽略年和日,返回指定时间段的月差数。

若unit="YD",则DATEDIF忽略年,返回指定时间段的日差数。

若method=1,则DATEDIF返回日期差值的绝对值。

若method=-1,则DATEDIF返回日期差值时,会考虑正负情况。

示例:

DATEDIF("2001/2/28","2004/3/20","Y")等于3,即在2001年2月28日与2004年3月20日之间有3个整年。

DATEDIF("2001/2/28","2004/3/20","M")等于37,即在2001年2月28日与2004年3月20日之间有36个整月。

DATEDIF("2001/2/28","2004/3/20","D")等于1116,即在2001年2月28日与2004年3月20日之间有1116个整天。

DATEDIF("2001/2/28","2004/3/20","MD")等于8,即忽略月和年后,2001年2月28日与2004年3月20日的差为8天。

DATEDIF("2001/1/28","2004/3/20","YM")等于2,即忽略日和年后,2001年1月28日与2004年3月20日的差为2个月。

DATEDIF("2001/2/28","2004/3/20","YD")等于21,即忽略年后,2001年2月28日与2004年3月20日的差为21天。

  • yzmfKZXQ1464691 yzmfKZXQ1464691(提问者) 这个是不是和他链接的数据库有关啊,这几个我都试了都是同样的报错
    2023-08-30 15:16 
  • snrtuemc snrtuemc 回复 yzmfKZXQ1464691(提问者) 不会吧,你确定是hana数据库?正常那个可以叠,真不行,直接帆软自带的公式计算吧。。。
    2023-08-30 15:17 
  • yzmfKZXQ1464691 yzmfKZXQ1464691(提问者) 回复 snrtuemc 我看工程信息是BWP类型是SAPhana
    2023-08-30 15:22 
  • snrtuemc snrtuemc 回复 yzmfKZXQ1464691(提问者) 以前sap有oracle数据库,不一定hana数据库。。
    2023-08-30 15:23 
  • yzmfKZXQ1464691 yzmfKZXQ1464691(提问者) 回复 snrtuemc 解决了,用SELECT DAYS_BETWEEN(\'2022-01-01\',\'2021-01-01\') AS A FROM XX表就行了
    2023-08-31 11:45 
  • 1关注人数
  • 149浏览人数
  • 最后回答于:2023-8-30 15:06
    请选择关闭问题的原因
    确定 取消
    返回顶部