如何修剪早于SQL Server 2017的MS SQL中的字符串?

Eri*_*sky 122 sql sql-server trim

在SQL Server 2017中,您可以使用此语法,但不能在早期版本中使用:

SELECT Name = TRIM(Name) FROM dbo.Customer;
Run Code Online (Sandbox Code Playgroud)

Ben*_*ein 223

SELECT LTRIM(RTRIM(Names)) AS Names FROM Customer
Run Code Online (Sandbox Code Playgroud)

  • @CodeBuster:即使在2014版本中,SQL Server也没有定义TRIM功能. (4认同)
  • SQL Server现在在2017版本中具有TRIM.https://docs.microsoft.com/en-us/sql/t-sql/functions/trim-transact-sql (4认同)
  • 这是最简单的方法,只需记住为返回的列添加别名 (3认同)
  • @Miles - 为了完整性,我添加了别名。 (2认同)
  • 我知道这是使用修剪价值的正确方法.但是,当我们只使用TRIM时你能解释为什么同时使用LTRIM和RTRIM吗? (2认同)

Kib*_*bee 60

要修剪右侧,请使用:

SELECT RTRIM(Names) FROM Customer
Run Code Online (Sandbox Code Playgroud)

要修剪左侧,请使用:

SELECT LTRIM(Names) FROM Customer
Run Code Online (Sandbox Code Playgroud)

要修改双方,请使用:

SELECT LTRIM(RTRIM(Names)) FROM Customer
Run Code Online (Sandbox Code Playgroud)

  • 是的,但这是两个函数调用.你可以说它们都是多余的,因为TSQL有CHARINDEX和SUBSTRING,但这是一种看待它的愚蠢方式. (49认同)
  • 这根本不是多余的.不提供称为TRIM的单个函数会给用户带来语法负担. (9认同)
  • 顺便提一下,微软有什么可能的理由来包括没有TRIM的LTRIM和RTRIM功能?这很特别. (4认同)
  • 这可能是一个疏忽,或者其中一个被削弱的功能,因为每个功能都从-100点开始(这实际上只会导致不连贯的功能集而不是优先功能集,恕我直言). (3认同)

one*_*hen 7

我认为这是一次性的数据清理练习.完成后,请确保添加数据库约束以防止将来出现错误数据,例如

ALTER TABLE Customer ADD
   CONSTRAINT customer_names__whitespace
      CHECK (
             Names NOT LIKE ' %'
             AND Names NOT LIKE '% '
             AND Names NOT LIKE '%  %'
            );
Run Code Online (Sandbox Code Playgroud)

另请考虑禁止可能导致问题的其他字符(制表符,回车符,换行符等).

这也可能是那些名字分成好时机family_name,first_name等:)


raz*_*zon 5

SELECT LTRIM(RTRIM(Replace(Replace(Replace(name,'   ',' '),CHAR(13), ' '),char(10), ' ')))
from author
Run Code Online (Sandbox Code Playgroud)