从varchar(36)到UNIQUEIDENTIFIER

时间:2010-04-23 12:42:37

标签: sql sql-server casting uniqueidentifier varchar

我正在尝试将UNIQUEIDENTIFIER的AuctionId投射到varchar(36),然后再投回到UNIQUEIDENTIFIER。请帮帮我。

CAST((SUBSTRING(CAST([AuctionId] as VARCHAR(36)), 0, 35) + '1') AS UNIQUEIDENTIFIER)

但我一直收到这个错误:

  

Msg 8169,Level 16,State 2,Line 647   转换时转换失败   一个字符串   唯一标识符

提前致谢

3 个答案:

答案 0 :(得分:5)

'1'不是问题。您显然是在尝试将GUID的最后一个字符更改为1.我不知道为什么,但这是您的要求。

您的问题是子字符串。在TSQL中,子串使用从1 而不是 0开始的索引,就像在C或C#中一样。这意味着你的substring语句实际上返回了一个34个字符的字符串(+1个字符组成35个,你被告知35个字符的字符串不是GUID,这是正确的。)

只需将,0,35更改为1,35

即可

答案 1 :(得分:3)

您的错误是由于您的+'1'和您的SUBSTRING造成的。那你在那里有什么?

这样可以正常使用

SELECT cast((cast(NEWID() as varchar(36))) as UNIQUEIDENTIFIER)

编辑:好的,所以如果你想用'1'替换最后一个字符,那么这就是解决方案

SELECT CAST(SUBSTRING(CAST(NEWID() AS VARCHAR(36)), 1, 35) + '1' AS UNIQUEIDENTIFIER)

唯一的区别是SQL中的SUBSTRING从位置1开始,而不是像你一样从位置0开始。

P.S。这是危险的代码。输出不再是GUID,因为它不符合用于生成GUID的算法。这可能(尽管不太可能)导致与GUID的冲突,这可能会导致各种问题。

答案 2 :(得分:2)

正如其他人所观察到的,目前尚不清楚为什么要做你正在做的事情。

SUBSTRING的替代STUFF命令:

SELECT stuff(cast([AuctionId] as varchar(36)),36,1,'1')