问题描述
所以我有以下表达式来转换儒略日期(格式为yyyy ###的AS400日期,其中#=日历天,即2020010 = 2020年1月10日,010是第十个日历日):
iif([JulianDateTable1]='',format(CONVERT(date,DATEADD(DAY,RIGHT([JulianDateTable2],3)-1,CONVERT(datetime,LEFT([JulianDateTable2],4)))),'YYYYMMDD'),RIGHT([JulianDateTable3],LEFT([JulianDateTable3],'YYYYMMDD')) AS agreementdate
运行此命令时,我收到以下错误消息:
从字符转换日期和/或时间时转换失败 字符串
不确定这是否与我尝试的日期格式“ YYYYMMDD”有关,但也尝试了“ MMddyy”并遇到相同的错误。
谢谢!
解决方法
您可以使用日期算术将此输入转换为正确的日期数据类型。如果朱利安日期存储为字符串:
dateadd(
day,convert(int,right(JulianDateTable2,3)) - 1,datefromparts(left(JulianDateTable2,4),1,1)
)
如果是整数值:
dateadd(
day,JulianDateTable2 % 1000 - 1,datefromparts(JulianDateTable2 / 1000,1)
)