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

Entfernen Sie seltsame Zeichen ( A mit Hut) aus der SQL Server-Varchar-Spalte

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:

  1. Öffnen Sie Visual Studio und erstellen Sie ein Class Library Project :

  2. 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));
        }
    }
    
  3. 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 folgenden FROM -Klausel, die mit Ihrer StackOverflow.dll übereinstimmt :

    CREATE ASSEMBLY [StackOverflow] FROM 'C:\Users\gotqn\Desktop\StackOverflow\StackOverflow\bin\Debug\StackOverflow.dll';
    
  4. 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