首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何将nvarchar转换为统一标识符?

如何将nvarchar转换为统一标识符?
EN

Stack Overflow用户
提问于 2019-12-05 17:10:07
回答 1查看 85关注 0票数 0

我有一个表(RPT.table1),它包含从ArcGIS联机应用程序导出的数据。表中的一个列(GlobalID)被导出为nvarchar(255)数据类型。在将此数据插入另一个表(CFAdmin.table2)之前,我需要将该列转换为CFAdmin.table2数据类型。

GlobalID列中的值曾经是唯一的标识符,并且已经包含连字符(B4A6AA96-42DF-48D9-A3E0-4C7F88ED3E1D)。

我试过用

代码语言:javascript
复制
ALTER TABLE RPT.table1 
ALTER COLUMN GlobalID uniqueidentifier;

INSERT INTO语句中

代码语言:javascript
复制
INSERT INTO CFAdmin.table2 (GlobalID)
    SELECT CAST(GlobalID AS uniqueidentifier)
    FROM RPT.table1;

对于这两种方法,我都会得到一个错误

Msg 8169,16级,状态2,第1行

将字符串转换为unique标识符时,转换失败。

我对Server还比较陌生,我猜想有一个非常简单的解决方案。

感谢您的阅读。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-12-05 17:23:01

数据可能有问题,而不是代码/语法问题。源表中可能有作为唯一标识符无效的值。我只需查看源表中的数据,并试图找到会导致错误的值,就会进行调查。查看此查询返回的内容:

代码语言:javascript
复制
Select GlobalID from RPT.table1 WHERE GlobalID NOT LIKE '________-____-____-____-____________'

(这些下划线模糊在一起,所以为了明确:8下划线,破折号,4下划线,破折号,12下划线)

或者检查一下

代码语言:javascript
复制
Select GlobalID from RPT.table1 WHERE GlobalID IS NULL
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59200135

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档