SQL Server 2008:如何查找尾随空格

时间:2010-03-31 11:22:29

标签: sql sql-server sql-server-2008 string

如何在列中找到具有尾随空格的所有列值?对于领先的空间,它只是

select col from table where substring(col,1,1) = ' ';

13 个答案:

答案 0 :(得分:56)

您可以使用LIKE找到尾随空格:

SELECT col FROM tbl WHERE col LIKE '% '

答案 1 :(得分:7)

SQL Server 2005:

select col from tbl where right(col, 1) = ' '

作为演示:

select 
    case when right('said Fred', 1) = ' ' then 1 else 0 end as NoTrail,
    case when right('said Fred ', 1) = ' ' then 1 else 0 end as WithTrail

返回

NoTrail WithTrail
0       1  

答案 2 :(得分:3)

一种非常简单的方法是使用LEN功能。 LEN将修剪尾随空格但不在空格之前,所以如果你的LEN()与你的LEN(REVERSE())不同,你将得到所有带尾随空格的行:

select col from table where LEN(col) <> LEN(REVERSE(col));

这也可以用来计算出更多高级逻辑的空间。

答案 3 :(得分:3)

这对我有用:

<script src="https://cdnjs.cloudflare.com/ajax/libs/react/0.14.8/react.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/0.14.8/react-dom.min.js"></script>
<div id="app"></div>

这将为您提供具有尾随空格的所有记录。

如果您想获得具有前导或尾随空格的记录,那么您可以使用它:

select * from table_name where column_name not like RTRIM(column_name)

答案 4 :(得分:1)

SELECT * FROM tbl WHERE LEN(col) != DATALENGTH(col)

也应该工作。

答案 5 :(得分:1)

有几种不同的方法可以做到这一点......

我最喜欢的选项,假设您的意图是删除任何前导和/或尾随空格,是执行以下操作,这将动态创建T-SQL到UPDATE所有列,其中包含不需要的空间到它们的修剪值:

SELECT 
'UPDATE [<DatabaseName>].[dbo].['+TABLE_NAME+']
SET ['+COLUMN_NAME+']=LTRIM(RTRIM(['+COLUMN_NAME+']))
WHERE ['+COLUMN_NAME+']=LTRIM(RTRIM(['+COLUMN_NAME+']));'+CHAR(13)
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME LIKE '<TableName>%' 
    AND DATA_TYPE!='date'
ORDER BY TABLE_NAME,COLUMN_NAME

如果您确实需要识别它们,请尝试以下查询之一:

SELECT *
FROM [database].[schema].[table]
WHERE [col1]!=LTRIM(RTRIM([col1]))

更动态的SQL:

SELECT 'SELECT ''['+TABLE_NAME+'].['+COLUMN_NAME+']'',*
FROM [<your database name>].[dbo].['+TABLE_NAME+']
WHERE ['+COLUMN_NAME+'] LIKE ''% ''
    OR ['+COLUMN_NAME+'] LIKE '' %'';
GO
'
FROM INFORMATION_SCHEMA.COLUMNS
WHERE TABLE_NAME LIKE '<filter table name as desired>%'
    AND DATA_TYPE!='date'

答案 6 :(得分:0)

SQL Server中忽略了空格,因此对我来说,即使领先的空间也无法正常工作。

select col from table where substring(col,1,1) = ' '
如果只有一个空格('')或空格('')

不会工作

所以我设计了以下内容:

select * from [table] where substring(REPLACE(col, ' ', '#'),1,1) = '#'

答案 7 :(得分:0)

这是尾随空格的另一种选择。

DECLARE @VALUE VARCHAR(50) = NULL

DECLARE @VALUE VARCHAR(50) = '  '

IF ((@VALUE IS NOT NULL) AND (LTRIM(RTRIM(@VALUE)) != ''))

BEGIN
   SELECT 'TRUE'
END
ELSE
BEGIN
   SELECT 'FALSE'
END

答案 8 :(得分:0)

试试这个:

UPDATE Battles
SET name = CASE WHEN (LEN(name+'a')-1)>LEN(RTRIM(name))
THEN REPLICATE(' ', (LEN(name+'a')-1)- LEN(RTRIM(name)))+RTRIM(name)
ELSE name
END

答案 9 :(得分:0)

我发现接受的答案要慢一点:

SELECT col FROM tbl WHERE col LIKE '% ';

反对这项技术:

SELECT col FROM tbl WHERE ASCII(RIGHT([value], 1)) = 32;

想法是获取最后一个字符,但将其ASCII代码与ASCII空间代码进行比较,而不是仅与' '(空间)进行比较。如果仅使用' '空间,则空字符串将产生true:

DECLARE @EmptyString NVARCHAR(12) = '';

SELECT IIF(RIGHT(@EmptyString, 1) = ' ', 1, 0); -- this returns 1

以上原因是由于Microsoft的implementation of string comparisons

那么,到底有多快?

您可以尝试以下代码:

CREATE TABLE #DataSource 
(
    [RowID] INT PRIMARY KEY IDENTITY(1,1)
   ,[value] NVARCHAR(1024)
);

INSERT INTO #DataSource ([value])
SELECT TOP (1000000) 'text ' + CAST(ROW_NUMBER() OVER(ORDER BY t1.number) AS VARCHAR(12)) 
FROM master..spt_values t1 
CROSS JOIN master..spt_values t2

UPDATE #DataSource
SET [value] = [value] + ' '
WHERE [RowID] = 100000;


SELECT *
FROM #DataSource
WHERE ASCII(RIGHT([value], 1)) = 32;

SELECT *
FROM #DataSource
WHERE [value] LIKE '% ';

在我的机器上,大约有1秒的差异:

enter image description here

我已经在具有60万行的表上对其进行了测试,但是它的大小更大,并且相差8秒以上。因此,准确的速度取决于您的实际案例数据。

答案 10 :(得分:0)

另一种使用 CHARINDEXREVERSE 实现此目的的方法,如下所示:

select col1 from table1
WHERE charindex(' ', reverse(col1)) = 1

参见示例 Here

答案 11 :(得分:-1)

以下是查找带有前导或尾随空格的记录的替代方法,包括标签等:

SELECT * FROM tbl WHERE NOT TRIM(col) = col

答案 12 :(得分:-1)

我们可以尝试使用下划线来查找空白条目,但不是像使用'%%'或''这样的准确解决方案,但我可以找到空白的条目。

从表中选择col_name,其中col_name类似于'_'