请告诉我如何将半空格替换为空格,sql server
例如:بیامو to بی ام و
select *
from test
where title like N'%بیامو%'
请告诉我如何将半空格替换为空格,sql server
例如:بیامو to بی ام و
select *
from test
where title like N'%بیامو%'
我不明白你所说的半空间是什么意思。但是您可以使用 Replace 功能来替换字符。
获取半空格或隐藏字符或零宽度空格的 unicode 非常重要,有时是“8204”,有时是“8203” 在下面的示例中,我们通过子字符串获取 unicode 编号然后替换它,其他对我来说重要的是整理它只适用于“SQL_Latin1_General_CP1_CI_AS”
DECLARE @UnicodeReplace NVARCHAR(5) = N'یآ'
-- check that unicode string length is 3,
-- and prove existence of zero-width space character matching unicode 8204
SELECT @UnicodeReplace AS String,
LEN(@UnicodeReplace) AS Length,
UNICODE(SUBSTRING(@UnicodeReplace, 2, 1)) AS UnicodeValue -- it gets you 8204
set @UnicodeReplace = N'یآ' collate Persian_100_CI_AS --+ NCHAR(8204)
-- replace and prove the unicode string length is reduced to 2
SELECT REPLACE(@UnicodeReplace collate SQL_Latin1_General_CP1_CI_AS , NCHAR(8204), ''),
LEN(REPLACE(@UnicodeReplace collate SQL_Latin1_General_CP1_CI_AS , NCHAR(8204), '')) AS Length