data:image/s3,"s3://crabby-images/2b829/2b8293212a9dc51f88208886e527e38cee9464b5" alt="clock"
December 16, 2014 07:30 by
Peter
Today, I am going to tell you how to replace the special characters in a string with spaces. In this case, I need to use PATINDEX.
data:image/s3,"s3://crabby-images/2a57b/2a57b9bd2604b549c107abf589b263a8ab13b861" alt=""
PATINDEX
It will returns the starting position of the first occurrence of a pattern in a specified expression, or zeros if the pattern is not found, on all valid text and character data types. And this is the code that I used:
PATINDEX ( '%pattern%' , expression )
Example:
DECLARE @Str varchar(100)
SET @Str='Welcome!@+to+#$%SQL+^&*(SERVER)_+'
SELECT PATINDEX('%SQL%', @Str)
Here is the result from that code:
data:image/s3,"s3://crabby-images/664b8/664b84a8fdc8f7dc3ff9fbe61c08ed65b5582a2d" alt=""
Remove Special Characters from String in SQL Server DECLARE @regexp INT
DECLARE @Str varchar(100)
SET @Str='Welcome!@+to+#$%SQL+^&*(SERVER)_+ '
SET @regexp = PATINDEX('%[^a-zA-Z0-9 ]%', @Str)
WHILE @regexp > 0
BEGIN
SET @Str = STUFF(@Str, @regexp, 1, ' ' )
SET @regexp = PATINDEX('%[^a-zA-Z0-9 ]%', @Str)
Print @regexp
END
SELECT @Str
Result:
data:image/s3,"s3://crabby-images/fed27/fed277a56812ff7517b3bc59947d354668df0f7f" alt=""
STUFF
This STUFF function inserts a string into another string. It deletes a specified length of characters in the first string at the start position and then inserts the second string into the first string at the start position. This is the code:
STUFF ( character_expression , start , length , replaceWith_expression )
Example:
DECLARE @regexp INT
DECLARE @Str varchar(100)
SET @Str='welcome to sql server'
SET @Str = STUFF(@Str, 1, 1, '@' )
Select @str
data:image/s3,"s3://crabby-images/efb01/efb016b3c2ee5835845c682856c075f36a4b20f1" alt=""