sql >> Databasteknik >  >> RDS >> Sqlserver

Ta bort konstiga tecken (A med hatt) från SQL Server varchar-kolumnen

Du kan använda .net reguljära uttrycksfunktioner. Till exempel genom att använda Regex.Replace :

Regex.Replace(s, @"[^\u0000-\u007F]", string.Empty);

Eftersom det inte finns stöd för reguljära uttryck i SQL Server du måste skapa en SQL CLR fungera. Mer information om .net integration i SQL Server finns här:

  • String Utility Functions Exempel - fullständiga arbetsexempel
  • Trappa till SQLCLR - fortfarande pågår
  • Introduktion till SQL Server CLR-integration - officiell dokumentation

I ditt fall:

  1. Öppna Visual Studio och skapa Class Library Project :

  2. Byt sedan namn på klassen till StackOverflow och klistra in följande kod i sin fil:

    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. Bygg nu projektet. Öppna SQL Server Management Studio . Välj din databas och ersätt sökvägsvärdet för följande FROM sats som matchar din StackOverflow.dll :

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

Du är redo att använda RegexReplace .net fungerar direkt i din T-SQL uttalanden:

    SELECT [dbo].[StackOverflowRegexReplace] ('Hello Kitty Essential Accessory Kit', '[^\u0000-\u007F]', '')

    //Hello Kitty Essential Accessory Kit


  1. Postgresql generera_serie av månader

  2. Konvertera 'datetime2' till 'time' i SQL Server (T-SQL-exempel)

  3. Oracle MINUS Operatör förklaras

  4. Vad är JDBC-motsvarigheten till Postgres \connect-kommando?