我有一个表(RPT.table1),它包含从ArcGIS联机应用程序导出的数据。表中的一个列(GlobalID)被导出为nvarchar(255)数据类型。在将此数据插入另一个表(CFAdmin.table2)之前,我需要将该列转换为CFAdmin.table2数据类型。
GlobalID列中的值曾经是唯一的标识符,并且已经包含连字符(B4A6AA96-42DF-48D9-A3E0-4C7F88ED3E1D)。
我试过用
ALTER TABLE RPT.table1
ALTER COLUMN GlobalID uniqueidentifier;在INSERT INTO语句中
INSERT INTO CFAdmin.table2 (GlobalID)
SELECT CAST(GlobalID AS uniqueidentifier)
FROM RPT.table1;对于这两种方法,我都会得到一个错误
Msg 8169,16级,状态2,第1行
将字符串转换为unique标识符时,转换失败。
我对Server还比较陌生,我猜想有一个非常简单的解决方案。
感谢您的阅读。
发布于 2019-12-05 17:23:01
数据可能有问题,而不是代码/语法问题。源表中可能有作为唯一标识符无效的值。我只需查看源表中的数据,并试图找到会导致错误的值,就会进行调查。查看此查询返回的内容:
Select GlobalID from RPT.table1 WHERE GlobalID NOT LIKE '________-____-____-____-____________'(这些下划线模糊在一起,所以为了明确:8下划线,破折号,4下划线,破折号,12下划线)
或者检查一下
Select GlobalID from RPT.table1 WHERE GlobalID IS NULLhttps://stackoverflow.com/questions/59200135
复制相似问题