SQL Server:有 strpos() 的等价物吗?
我正在处理一个烦人的数据库,其中一个字段包含真正应该存储在两个单独字段中的内容。 因此该列存储的内容类似于“第一个字符串~@~第二个字符串”,其中“~@~”是分隔符。 (再说一遍,我没有设计这个,我只是想修复它。)
我想要一个查询将其移动到两列中,看起来像这样:
UPDATE UserAttributes
SET str1 = SUBSTRING(Data, 1, STRPOS(Data, '~@~')),
str2 = SUBSTRING(Data, STRPOS(Data, '~@~')+3, LEN(Data)-(STRPOS(Data, '~@~')+3))
但我找不到任何与 strpos 等效的存在。
I'm dealing with an annoying database where one field contains what really should be stored two separate fields. So the column is stored something like "The first string~@~The second string", where "~@~" is the delimiter. (Again, I didn't design this, I'm just trying to fix it.)
I want a query to move this into two columns, that would look something like this:
UPDATE UserAttributes
SET str1 = SUBSTRING(Data, 1, STRPOS(Data, '~@~')),
str2 = SUBSTRING(Data, STRPOS(Data, '~@~')+3, LEN(Data)-(STRPOS(Data, '~@~')+3))
But I can't find that any equivalent to strpos exists.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
用户 charindex:
链接
User charindex:
Link
PatIndex 函数应该为您提供模式的位置作为字符串的一部分。
http://msdn.microsoft.com/en-us/library/ms188395.aspx
The PatIndex function should give you the location of the pattern as a part of a string.
http://msdn.microsoft.com/en-us/library/ms188395.aspx
如果您需要列中的数据,这就是我使用的:
只需将函数中的“,”替换为您的分隔符(或者甚至可以对其进行参数化)
If you need your data in columns here is what I use:
Just replace ',' in the function with your delimiter (or maybe even parametrize it)