Sie können .net
verwenden reguläre Ausdrucksfunktionen. Verwenden Sie zum Beispiel Regex.Replace
:
Regex.Replace(s, @"[^\u0000-\u007F]", string.Empty);
Da es in SQL Server
keine Unterstützung für reguläre Ausdrücke gibt Sie müssen eine SQL CLR
erstellen Funktion. Weitere Informationen zu .net
Integration in SQL Server
finden Sie hier:
- Beispiel für String-Hilfsfunktionen - vollständige Arbeitsbeispiele
- Stairway to SQLCLR - noch in Bearbeitung
- Einführung in die SQL Server CLR-Integration – offizielle Dokumentation
In Ihrem Fall:
-
Öffnen Sie
Visual Studio
und erstellen Sie einClass Library Project
: -
Benennen Sie die Klasse dann in
StackOverflow
um und fügen Sie den folgenden Code in seine Datei ein:using Microsoft.SqlServer.Server; using System; using System.Collections.Generic; using System.Data.SqlTypes; using System.Linq; using System.Text; using System.Text.RegularExpressions; using System.Threading.Tasks; public class StackOverflow { [SqlFunction(DataAccess = DataAccessKind.None, IsDeterministic = true, Name = "RegexReplace")] public static SqlString Replace(SqlString sqlInput, SqlString sqlPattern, SqlString sqlReplacement) { string input = (sqlInput.IsNull) ? string.Empty : sqlInput.Value; string pattern = (sqlPattern.IsNull) ? string.Empty : sqlPattern.Value; string replacement = (sqlReplacement.IsNull) ? string.Empty : sqlReplacement.Value; return new SqlString(Regex.Replace(input, pattern, replacement)); } }
-
Erstellen Sie nun das Projekt. Öffnen Sie das
SQL Server Management Studio
. Wählen Sie Ihre Datenbank aus und ersetzen Sie den Pfadwert durch den folgendenFROM
-Klausel, die mit IhrerStackOverflow.dll
übereinstimmt :CREATE ASSEMBLY [StackOverflow] FROM 'C:\Users\gotqn\Desktop\StackOverflow\StackOverflow\bin\Debug\StackOverflow.dll';
-
Erstellen Sie abschließend die
SQL CLR
Funktion:CREATE FUNCTION [dbo].[StackOverflowRegexReplace] (@input NVARCHAR(MAX),@pattern NVARCHAR(MAX), @replacement NVARCHAR(MAX)) RETURNS NVARCHAR(4000) AS EXTERNAL NAME [StackOverflow].[StackOverflow].[Replace] GO
Sie können jetzt RegexReplace
verwenden .net
Funktion direkt in Ihrem T-SQL
Anweisungen:
SELECT [dbo].[StackOverflowRegexReplace] ('Hello Kitty Essential Accessory Kit', '[^\u0000-\u007F]', '')
//Hello Kitty Essential Accessory Kit