8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

如何删除 SQL Server 中某个字符之前的所有内容?

Gereon will not feed AI 2月前

46 0

我已经将数据输入到我的 SQL 服务器中。我想删除连字符前的所有字符。\'-\' 之前的字符数量不同。例如:ABC-123AB-424ABCD-53214 我...

我已经将数据输入到 SQL 服务器中。我想删除连字符前的所有字符。\'-\' 之前的字符数量不同。

例如:

ABC-123
AB-424
ABCD-53214

我想要这样的结果:

123
424
53214

我是 SQL Server 新手,确实需要帮助。
先感谢您。

帖子版权声明 1、本帖标题:如何删除 SQL Server 中某个字符之前的所有内容?
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Gereon will not feed AI在本站《sql》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 就我个人而言,我更喜欢使用 STUFF 来执行此操作,而不是 RIGHT 。 这样您就不需要获取值的长度。 CHARINDEX 但您仍然需要获取角色的位置:

    STUFF(YourColumn, 1, CHARINDEX('-',YourColumn),'')
    

    因此,这将获取 的值 YourColumn ,然后 1 用零长度字符串 ( - ) YourColumn 字符位置 ''

    如果您不想在字符不在字符串中时返回字符串,则可以添加 NULLIF , 以将 0 更改 CHARINDEX NULL .

    STUFF(YourColumn, 1, NULLIF(CHARINDEX('-',YourColumn),0),'')
    

    工作示例:

    SELECT V.YourColumn,
           STUFF(YourColumn, 1, CHARINDEX('-',YourColumn),'') AS RemoveUpToDelimiter,
           STUFF(YourColumn, 1, NULLIF(CHARINDEX('-',YourColumn),0),'')  AS RemoveUpToDelimiter_NULLifNone
    FROM (VALUES('ABC-123'),
                ('AB-424'),
                ('ABCD-53214'),
                ('789'))V(YourColumn);
    
  • 可能是另一种方法,你可以通过使用反向和 Char Index

    DECLARE  @Table1 TABLE 
        (val varchar(10))
    ;
    
    INSERT INTO @Table1
        (val)
    VALUES
    ('ABC-123'),
        ('AB- 424'),
        ('ABCD-53214')
    select reverse(substring(reverse(val),0,CHARINDEX('-',reverse(val)))) from @Table1
    
  • 尝试一下:

    right(MyColumn, len(MyColumn) - charindex('-', MyColumn))
    

    Charindex 查找连字符的位置, len 查找整个字符串的长度,并 right 返回字符串右侧指定数量的字符。

  • 查看 SUBSTRING 和 CHARINDEX。这个问题在这里已经被回答了数百次……仅今天就至少回答了两次。

返回
作者最近主题: