Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Wie ersetze ich mehrere Zeichen in SQL?

Ein nützlicher Trick in SQL ist die Möglichkeit, @var = function(...) zu verwenden einen Wert zuweisen. Wenn Sie mehrere Datensätze in Ihrem Datensatz haben, wird Ihre Variable mehrfach zugewiesen, mit Nebeneffekten:

declare @badStrings table (item varchar(50))

INSERT INTO @badStrings(item)
SELECT '>' UNION ALL
SELECT '<' UNION ALL
SELECT '(' UNION ALL
SELECT ')' UNION ALL
SELECT '!' UNION ALL
SELECT '?' UNION ALL
SELECT '@'

declare @testString varchar(100), @newString varchar(100)

set @teststring = 'Juliet ro><0zs my s0x()[email protected]@[email protected]!'
set @newString = @testString

SELECT @newString = Replace(@newString, item, '') FROM @badStrings

select @newString -- returns 'Juliet ro0zs my s0xrzone'