Puoi usare .net
funzioni di espressione regolare. Ad esempio, utilizzando Regex.Replace
:
Regex.Replace(s, @"[^\u0000-\u007F]", string.Empty);
Poiché non è disponibile il supporto per le espressioni regolari in SQL Server
devi creare un SQL CLR
funzione. Maggiori informazioni su .net
integrazione in SQL Server
può essere trovato qui:
- Esempio di funzioni di utilità per le stringhe - esempi di lavoro completi
- Scala per SQLCLR - ancora in corso
- Introduzione all'integrazione CLR di SQL Server - documentazione ufficiale
Nel tuo caso:
-
Apri
Visual Studio
e creaClass Library Project
: -
Quindi rinomina la classe in
StackOverflow
e incolla il seguente codice nel suo file: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)); } }
-
Ora costruisci il progetto. Apri
SQL Server Management Studio
. Seleziona il tuo database e sostituisci il valore del percorso del seguenteFROM
clausola in modo che corrisponda al tuoStackOverflow.dll
:CREATE ASSEMBLY [StackOverflow] FROM 'C:\Users\gotqn\Desktop\StackOverflow\StackOverflow\bin\Debug\StackOverflow.dll';
-
Infine, crea il
SQL CLR
funzione:CREATE FUNCTION [dbo].[StackOverflowRegexReplace] (@input NVARCHAR(MAX),@pattern NVARCHAR(MAX), @replacement NVARCHAR(MAX)) RETURNS NVARCHAR(4000) AS EXTERNAL NAME [StackOverflow].[StackOverflow].[Replace] GO
Sei pronto per usare RegexReplace
.net
funzione direttamente nel tuo T-SQL
dichiarazioni:
SELECT [dbo].[StackOverflowRegexReplace] ('Hello Kitty Essential Accessory Kit', '[^\u0000-\u007F]', '')
//Hello Kitty Essential Accessory Kit