在SQL Server 2017中,您可以使用此语法,但不能在早期版本中使用:
SELECT Name = TRIM(Name) FROM dbo.Customer;
Ben Hoffstei.. 223
SELECT LTRIM(RTRIM(Names)) AS Names FROM Customer
@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认同)
我知道这是使用修剪价值的正确方法.但是,当我们只使用TRIM时你能解释为什么同时使用LTRIM和RTRIM吗? (2认同)
Kibbee.. 60
要修剪右侧,请使用:
SELECT RTRIM(Names) FROM Customer
要修剪左侧,请使用:
SELECT LTRIM(Names) FROM Customer
要修改双方,请使用:
SELECT LTRIM(RTRIM(Names)) FROM Customer
是的,但这是两个函数调用.你可以说它们都是多余的,因为TSQL有CHARINDEX和SUBSTRING,但这是一种看待它的愚蠢方式. (49认同)
这根本不是多余的.不提供称为TRIM的单个函数会给用户带来语法负担. (9认同)
顺便提一下,微软有什么可能的理由来包括没有TRIM的LTRIM和RTRIM功能?这很特别. (4认同)
这可能是一个疏忽,或者其中一个被削弱的功能,因为每个功能都从-100点开始(这实际上只会导致不连贯的功能集而不是优先功能集,恕我直言). (3认同)
onedaywhen.. 7
我认为这是一次性的数据清理练习.完成后,请确保添加数据库约束以防止将来出现错误数据,例如
ALTER TABLE Customer ADD CONSTRAINT customer_names__whitespace CHECK ( Names NOT LIKE ' %' AND Names NOT LIKE '% ' AND Names NOT LIKE '% %' );
另请考虑禁止可能导致问题的其他字符(制表符,回车符,换行符等).
这也可能是那些名字分成好时机family_name
,first_name
等:)
SELECT LTRIM(RTRIM(Names)) AS Names FROM Customer
要修剪右侧,请使用:
SELECT RTRIM(Names) FROM Customer
要修剪左侧,请使用:
SELECT LTRIM(Names) FROM Customer
要修改双方,请使用:
SELECT LTRIM(RTRIM(Names)) FROM Customer
我认为这是一次性的数据清理练习.完成后,请确保添加数据库约束以防止将来出现错误数据,例如
ALTER TABLE Customer ADD CONSTRAINT customer_names__whitespace CHECK ( Names NOT LIKE ' %' AND Names NOT LIKE '% ' AND Names NOT LIKE '% %' );
另请考虑禁止可能导致问题的其他字符(制表符,回车符,换行符等).
这也可能是那些名字分成好时机family_name
,first_name
等:)