如何在列中找到具有尾随空格的所有列值?对于领先的空间,它只是
select col from table where substring(col,1,1) = ' ';
答案 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秒的差异:
我已经在具有60万行的表上对其进行了测试,但是它的大小更大,并且相差8秒以上。因此,准确的速度取决于您的实际案例数据。
答案 10 :(得分:0)
另一种使用 CHARINDEX 和 REVERSE 实现此目的的方法,如下所示:
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类似于'_'