SQL Server 2008で文字列からすべてのスペースを削除するための最良の方法は何ですか?
LTRIM(RTRIM(' a b '))
は文字列の左右のスペースをすべて削除しますが、中央のスペースも削除する必要があります。
交換するだけです。
SELECT REPLACE(fld_or_variable, ' ', '')
編集: 明確にするためだけに;これはグローバルに置き換えられるので、trim()
やchar
とvarchar
のどちらについても複数のスペースを心配する必要はありません。
create table #t (
c char(8),
v varchar(8))
insert #t (c, v) values
('a a' , 'a a' ),
('a a ' , 'a a ' ),
(' a a' , ' a a' ),
(' a a ', ' a a ')
select
'"' + c + '"' [IN], '"' + replace(c, ' ', '') + '"' [OUT]
from #t
union all select
'"' + v + '"', '"' + replace(v, ' ', '') + '"'
from #t
結果
IN OUT
===================
"a a " "aa"
"a a " "aa"
" a a " "aa"
" a a " "aa"
"a a" "aa"
"a a " "aa"
" a a" "aa"
" a a " "aa"
それがテーブルの更新である場合は、0行に影響が及ぶまでこの更新を複数回実行するだけです。
update tableName
set colName = REPLACE(LTRIM(RTRIM(colName)), ' ', ' ')
where colName like '% %'
REPLACE(field, ' ', '')
まず、サンプルのテーブルとデータを作成します。
CREATE TABLE tbl_RemoveExtraSpaces
(
Rno INT
,Name VARCHAR(100)
)
GO
INSERT INTO tbl_RemoveExtraSpaces VALUES (1,'I am Anvesh Patel')
INSERT INTO tbl_RemoveExtraSpaces VALUES (2,'Database Research and Development ')
INSERT INTO tbl_RemoveExtraSpaces VALUES (3,'Database Administrator ')
INSERT INTO tbl_RemoveExtraSpaces VALUES (4,'Learning BIGDATA and NOSQL ')
GO
余分なスペースなしで文字列をSELECTするスクリプト:
SELECT
[Rno]
,[Name] AS StringWithSpace
,LTRIM(RTRIM(REPLACE(REPLACE(REPLACE([Name],CHAR(32),'()'),')(',''),'()',CHAR(32)))) AS StringWithoutSpace
FROM tbl_RemoveExtraSpaces
結果:
Rno StringWithSpace StringWithoutSpace
----------- ----------------------------------------- ---------------------------------------------
1 I am Anvesh Patel I am Anvesh Patel
2 Database Research and Development Database Research and Development
3 Database Administrator Database Administrator
4 Learning BIGDATA and NOSQL Learning BIGDATA and NOSQL
t-sqlの置き換え http://msdn.Microsoft.com/ja-jp/library/ms186862.aspx
(val、 ''、 '')を置き換えます
100%ワーキング
UPDATE table_name SET "column_name"=replace("column_name", ' ', ''); //Remove white space
UPDATE table_name SET "column_name"=replace("column_name", '\n', ''); //Remove newline
UPDATE table_name SET "column_name"=replace("column_name", '\t', ''); //Remove all tab
"column_name"
またはcolumn_name
を使用できます
ありがとう
スブロト
文字列に複数の空白があると、replaceは正しく機能しない可能性があります。そのためには、以下の関数を使うべきです。
CREATE FUNCTION RemoveAllSpaces
(
@InputStr varchar(8000)
)
RETURNS varchar(8000)
AS
BEGIN
declare @ResultStr varchar(8000)
set @ResultStr = @InputStr
while charindex(' ', @ResultStr) > 0
set @ResultStr = replace(@InputStr, ' ', '')
return @ResultStr
END
例:
select dbo.RemoveAllSpaces('aa aaa aa aa a')
出力:
aaaaaaaaaa
これは、文字列のスペースを削除するためのトリックです。
UPDATE
tablename
SET
columnname = replace(columnname, ' ', '');
ちょっと一言、replace関数に問題がある場合には、データ型をncharに設定してください(この場合、それは固定長であり機能しません)。
万が一すべての列のスペースをトリムする必要がある場合は、このスクリプトを使用して動的に行うことができます。
--Just change table name
declare @MyTable varchar(100)
set @MyTable = 'MyTable'
--temp table to get column names and a row id
select column_name, ROW_NUMBER() OVER(ORDER BY column_name) as id into #tempcols from INFORMATION_SCHEMA.COLUMNS
WHERE DATA_TYPE IN ('varchar', 'nvarchar') and TABLE_NAME = @MyTable
declare @tri int
select @tri = count(*) from #tempcols
declare @i int
select @i = 0
declare @trimmer nvarchar(max)
declare @comma varchar(1)
set @comma = ', '
--Build Update query
select @trimmer = 'UPDATE [dbo].[' + @MyTable + '] SET '
WHILE @i <= @tri
BEGIN
IF (@i = @tri)
BEGIN
set @comma = ''
END
SELECT @trimmer = @trimmer + CHAR(10)+ '[' + COLUMN_NAME + '] = LTRIM(RTRIM([' + COLUMN_NAME + ']))'+@comma
FROM #tempcols
where id = @i
select @i = @i+1
END
--execute the entire query
EXEC sp_executesql @trimmer
drop table #tempcols
上記のすべての答えを完全にするために、すべての空白文字を処理する方法に関するStackOverflowに関する追加の投稿があります(これらの文字の完全なリストについては https://en.wikipedia.org/wiki/Whitespace_character を参照)。 :
文字列からスペース、 - 、その他のテキストを削除する場合は、次のようにします。
あなたのテーブルに '718-378-4957'や '7183784957'のような携帯電話番号があり、それを置き換えて携帯電話番号を取得したい場合は、次のテキストを使用します。
select replace(replace(replace(replace(MobileNo,'-',''),'(',''),')',''),' ','') from EmployeeContactNumber
結果: - 7183784957
replace(replace(column_Name、CHAR(13)、 '')、CHAR(10)、 '')
誰もが単一のREPLACE関数を参照し続けているようです。あるいは、REPLACE関数の多くの呼び出しです。ただし、スペースの数が不明な動的出力がある場合は機能しません。この問題を定期的に処理する人は誰でも、REPLACEが削除すべきなのはすべてではなく単一のスペースのみを削除することを知っています。そして、LTRIMとRTRIMには同じ問題があるようです。 Microsoftにお任せください。以下は、WHILEループを使用してすべてのCHAR(32)値(スペース)を削除するサンプル出力です。
DECLARE @INPUT_VAL VARCHAR(8000)
DECLARE @OUTPUT_VAL VARCHAR(8000)
SET @INPUT_VAL = ' C A '
SET @OUTPUT_VAL = @INPUT_VAL
WHILE CHARINDEX(CHAR(32), @OUTPUT_VAL) > 0 BEGIN
SET @OUTPUT_VAL = REPLACE(@INPUT_VAL, CHAR(32), '')
END
PRINT 'START:' + @INPUT_VAL + ':END'
PRINT 'START:' + @OUTPUT_VAL + ':END'
上記のコードの出力は次のとおりです。
START: C A :END
START:CA:END
さらに一歩進んでUPDATEまたはSELECTステートメントで使用するには、udfに変更します。
CREATE FUNCTION udf_RemoveSpaces (@INPUT_VAL VARCHAR(8000))
RETURNS VARCHAR(8000)
AS
BEGIN
DECLARE @OUTPUT_VAL VARCHAR(8000)
SET @OUTPUT_VAL = @INPUT_VAL
-- ITTERATE THROUGH STRING TO LOOK FOR THE ASCII VALUE OF SPACE (CHAR(32)) REPLACE IT WITH BLANK, NOT NULL
WHILE CHARINDEX(CHAR(32), @OUTPUT_VAL) > 0 BEGIN
SET @OUTPUT_VAL = REPLACE(@INPUT_VAL, CHAR(32), '')
END
RETURN @OUTPUT_VAL
END
次に、SELECTまたはINSERTステートメントで関数を使用します。
UPDATE A
SET STATUS_REASON_CODE = WHATEVER.dbo.udf_RemoveSpaces(STATUS_REASON_CODE)
FROM WHATEVER..ACCT_INFO A
WHERE A.SOMEVALUE = @SOMEVALUE
INSERT INTO SOMETABLE
(STATUS_REASON_CODE)
SELECT WHATEVER.dbo.udf_RemoveSpaces(STATUS_REASON_CODE)
FROM WHATEVER..ACCT_INFO A
WHERE A.SOMEVALUE = @SOMEVALUE
私は今日この問題を抱えていて、交換/トリムはトリックをしました..下記を見てください。
update table_foo
set column_bar = REPLACE(LTRIM(RTRIM(column_bar)), ' ', '')
前後に:
old-bad: column_bar | New-fixed: column_bar
' xyz ' | 'xyz'
' xyz ' | 'xyz'
' xyz ' | 'xyz'
' xyz ' | 'xyz'
' xyz ' | 'xyz'
' xyz ' | 'xyz'
これは私には便利です:
CREATE FUNCTION dbo.TRIM(@String VARCHAR(MAX))
RETURNS VARCHAR(MAX)
BEGIN
RETURN LTRIM(RTRIM(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(REPLACE(@String,CHAR(10),'[]'),CHAR(13),'[]'),char(9),'[]'),CHAR(32),'[]'),'][',''),'[]',CHAR(32))));
END
GO
。
何らかの理由で、置換は毎回1つの文字列でのみ機能します。私はこのような " Test MSP "のような文字列を持っていて、1つのスペースだけを残したいのです。
@Farhanが行った方法を使用しましたが、いくつか変更を加えました。
CREATE FUNCTION ReplaceAll
(
@OriginalString varchar(8000),
@StringToRemove varchar(20),
@StringToPutInPlace varchar(20)
)
RETURNS varchar(8000)
AS
BEGIN
declare @ResultStr varchar(8000)
set @ResultStr = @OriginalString
while charindex(@StringToRemove, @ResultStr) > 0
set @ResultStr = replace(@ResultStr, @StringToRemove, @StringToPutInPlace)
return @ResultStr
END
それから私はこのように私のアップデートを実行します
UPDATE tbTest SET Description = dbo.ReplaceAll(Description, ' ', ' ') WHERE ID = 14225
それから私はこの結果を得ました: テストMSP
念のためにここに投稿してください。
実行環境:Microsoft SQL Server 2016(SP2)
特定の文字を置き換えるための構文:
REPLACE ( string_expression , string_pattern , string_replacement )
たとえば、文字列 "HelloReplaceThingsGoing"の中でReplace WordはHowに置き換えられます。
SELECT REPLACE('HelloReplaceThingsGoing','Replace','How');
GO
左右の文字列のスペースを削除します。途中でスペースを削除するにはReplace
を使います。
右からスペースを削除するにはRTRIM()
を使用し、左からスペースを削除するにはLTRIM()
を使用すると、次のように左右のスペースを削除できます。
SELECT * FROM table WHERE LTRIM(RTRIM(username)) = LTRIM(RTRIM("Bob alias baby"))
スペース、cr、lf、タブ、または構成可能変数を削除する機能バージョン(udf)。
select Common.ufn_RemoveWhitespace(' 234 asdf wefwef 3 x ', default) as S
結果: '234asdfwefwef3x'
alter function Common.RemoveWhitespace
(
@pString nvarchar(max),
@pWhitespaceCharsOpt nvarchar(max) = null -- default: tab, lf, cr, space
)
returns nvarchar(max) as
/*--------------------------------------------------------------------------------------------------
Purpose: Compress whitespace
Example: select Common.ufn_RemoveWhitespace(' 234 asdf wefwef 3 x ', default) as s
-- Result: 234asdfwefwef3x
Modified By Description
---------- ----------- --------------------------------------------------------------------
2018.07.24 crokusek Initial Version
--------------------------------------------------------------------------------------------------*/
begin
declare
@maxLen bigint = 1073741823, -- (2^31 - 1) / 2 (https://stackoverflow.com/a/4270085/538763)
@whitespaceChars nvarchar(30) = coalesce(
@pWhitespaceCharsOpt,
char(9) + char(10) + char(13) + char(32)); -- tab, lf, cr, space
declare
@whitespacePattern nvarchar(30) = '%[' + @whitespaceChars + ']%',
@nonWhitespacePattern nvarchar(30) = '%[^' + @whitespaceChars + ']%',
@previousString nvarchar(max) = '';
while (@pString != @previousString)
begin
set @previousString = @pString;
declare
@whiteIndex int = patindex(@whitespacePattern, @pString);
if (@whiteIndex > 0)
begin
declare
@whitespaceLength int = nullif(patindex(@nonWhitespacePattern, substring(@pString, @whiteIndex, @maxLen)), 0) - 1;
set @pString =
substring(@pString, 1, @whiteIndex - 1) +
iif(@whiteSpaceLength > 0, substring(@pString, @whiteIndex + @whiteSpaceLength, @maxLen), '');
end
end
return @pString;
end
go