.net
を使用できます 正規表現関数。たとえば、Regex.Replace
を使用します :
Regex.Replace(s, @"[^\u0000-\u007F]", string.Empty);
SQL Server
では正規表現がサポートされていないため SQL CLR
を作成する必要があります 働き。 .net
に関する詳細情報 SQL Server
への統合 ここで見つけることができます:
- 文字列ユーティリティ関数のサンプル-完全な実例
- SQLCLRへの階段-まだ進行中
- SQLServerCLR統合の概要-公式ドキュメント
あなたの場合:
-
Visual Studio
を開きますClass Library Project
を作成します : -
次に、クラスの名前を
StackOverflow
に変更します 次のコードをファイルに貼り付けます: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)); } }
-
次に、プロジェクトをビルドします。
SQL Server Management Studio
を開きます 。データベースを選択し、次のFROM
のパス値を置き換えますStackOverflow.dll
に一致する句 :CREATE ASSEMBLY [StackOverflow] FROM 'C:\Users\gotqn\Desktop\StackOverflow\StackOverflow\bin\Debug\StackOverflow.dll';
-
最後に、
SQL CLR
を作成します 機能:CREATE FUNCTION [dbo].[StackOverflowRegexReplace] (@input NVARCHAR(MAX),@pattern NVARCHAR(MAX), @replacement NVARCHAR(MAX)) RETURNS NVARCHAR(4000) AS EXTERNAL NAME [StackOverflow].[StackOverflow].[Replace] GO
RegexReplace
を使用する準備ができました .net
T-SQL
で直接機能する ステートメント:
SELECT [dbo].[StackOverflowRegexReplace] ('Hello Kitty Essential Accessory Kit', '[^\u0000-\u007F]', '')
//Hello Kitty Essential Accessory Kit