我收到一个错误,上面写着ODBC_Connector_14,0: ODBC function "SQLExecute" reported: SQLSTATE = 22008: Native Error Code = 0: Msg = [IBM (DataDirect OEM)][ODBC SQL Server Driver]Datetime field overflow (CC_OdbcDBStatement::executeInsert, file CC_OdbcDBStatement.cpp, line 834)。我的输入数据类型在源中是Date,我使用select语句,源的输出我将其设置为长度和比例=0的日期列,在数据库中,我也将它们的长度和比例设置为0,但不知何故它并没有消除错误,而且不知何故并不是所有记录都输入到数据库中。到底哪里出了问题?如果它确实需要长度和小数位数,我不知道如何从select语句中确定它,我也没有看到任何关于日期长度/小数位数的错误消息。它只是简单的Datetime溢出。如何解决这个问题?
发布于 2020-09-29 14:55:23
这是SELECT语句还是INSERT/UPDATE语句?
SELECT中出现日期溢出的情况很少见,因为它已经是数据库表中的日期。
在INSERT/UPDATE时,提供的值可能太大,数据库服务器无法处理。对于不同的数据库,最大可能日期是不同的。
顺便说一句,您不需要为Date数据类型提供长度。它将被忽略。
https://stackoverflow.com/questions/64112729
复制相似问题