我有一个有200列的巨大的INSERT-statement,突然我得到了可怕的Error converting data type varchar to numeric。有没有什么地方我可以看到包含"varchar“值的实际列?我知道我可以一次删除一列,直到错误消失,但这非常单调乏味。
发布于 2010-07-02 00:18:09
不幸的是,这个错误是一个严重的痛苦,并且没有简单的方法来解决它。当我在过去遇到它时,我总是不得不注释掉一组列,直到我找到罪魁祸首。
另一种方法可能是在T-SQL中使用中的ISNUMERIC()函数来尝试找到罪魁祸首。假设目标表中的每一列都是数字(如果不是,则相应地进行调整),您可以尝试这样做:
SELECT *
FROM SourceTable
WHERE ISNUMERIC(Column1) = 0
OR ISNUMERIC(Column2) = 0
OR ISNUMERIC(Column3) = 0
OR ISNUMERIC(Column4) = 0
...这将公开包含非数字值的行,并且应该非常清楚它在哪一列中。我知道这很单调乏味,但至少它可以帮助您找到实际的值,以及造成麻烦的列。
发布于 2010-07-01 18:01:58
好吧,这只是一种预感,但是将数据插入到临时表中并使用GUI将数据迁移到另一个表中又如何呢?如果它仍然产生一个错误,你至少应该能够得到更多关于非数字列的反馈……
如果不起作用,可以考虑尝试使用this.
干杯!
https://stackoverflow.com/questions/3156640
复制相似问题