首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从varchar(36)到UNIQUEIDENTIFIER

从varchar(36)到UNIQUEIDENTIFIER
EN

Stack Overflow用户
提问于 2010-04-23 12:42:36
回答 3查看 8.5K关注 0票数 1

我正在尝试将AuctionId转换为UNIQUEIDENTIFIERvarchar(36),然后返回到UNIQUEIDENTIFIER。请帮帮我。

代码语言:javascript
复制
CAST((SUBSTRING(CAST([AuctionId] as VARCHAR(36)), 0, 35) + '1') AS UNIQUEIDENTIFIER)

但是我不断地发现这个错误:

Msg 8169,级别16,状态2,行647转换失败时,从字符串转换为统一标识符。

提前感谢

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2010-04-23 12:50:14

“1”不是问题所在。你显然是想把GUID的最后一个字符改为1,我不知道为什么,但这是你的要求。

您的问题在于子字符串。在TSQL中,子字符串使用从1开始的索引,而不是0,类似于C或C#中的索引。这意味着您的子字符串语句实际上返回了一个34个字符串(+1个字符使35个字符生成35,并且告诉您35个字符串不是GUID,这是正确的)。

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

票数 5
EN

Stack Overflow用户

发布于 2010-04-23 12:47:18

您的错误是由于您的+'1‘和您的超级。你那里面有什么用的?

这会很好的

代码语言:javascript
复制
SELECT cast((cast(NEWID() as varchar(36))) as UNIQUEIDENTIFIER)

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

代码语言:javascript
复制
SELECT CAST(SUBSTRING(CAST(NEWID() AS VARCHAR(36)), 1, 35) + '1' AS UNIQUEIDENTIFIER)

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

这是危险密码。输出不再是GUID,因为它将不符合用于生成GUID的算法。这可能(虽然不太可能)导致与GUID的冲突,这可能会导致各种问题。

票数 3
EN

Stack Overflow用户

发布于 2010-04-23 12:54:47

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

SUBSTRING的一个替代方法是STUFF命令:

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

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/2698526

复制
相关文章

相似问题

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