当前位置:  开发笔记 > 数据库 > 正文

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

如何解决《如何修剪早于SQLServer2017的MSSQL中的字符串?》经验,为你挑选了3个好方法。

在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等:)



1> Ben Hoffstei..:
SELECT LTRIM(RTRIM(Names)) AS Names FROM Customer


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

2> Kibbee..:

要修剪右侧,请使用:

SELECT RTRIM(Names) FROM Customer

要修剪左侧,请使用:

SELECT LTRIM(Names) FROM Customer

要修改双方,请使用:

SELECT LTRIM(RTRIM(Names)) FROM Customer


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

3> onedaywhen..:

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

ALTER TABLE Customer ADD
   CONSTRAINT customer_names__whitespace
      CHECK (
             Names NOT LIKE ' %'
             AND Names NOT LIKE '% '
             AND Names NOT LIKE '%  %'
            );

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

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

推荐阅读
谢谢巷议
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有