SQL Server の varchar 列から不要な文字を削除する
外部ソースからインポートされたデータには、SQL Server の varchar 列から削除する必要がある予期しない文字または非標準の文字が含まれていることがよくあります。 この記事では、C# と SQL CLR 関数の両方を使用してこの問題に対処する方法を説明します。
正規表現を使用した C# ソリューション
.NET の正規表現エンジンは、これを処理する強力な方法を提供します。次の C# コードでは、Regex.Replace
を使用して印刷不可能な文字を削除します。
<code class="language-csharp">Regex.Replace(inputString, @"[^\u0000-\u007F]", string.Empty);</code>
機能強化のための SQL CLR 関数
SQL Server にはネイティブの正規表現サポートがないため、SQL CLR 関数を作成すると機能が拡張されます。 以下の例 StackOverflowRegexReplace
は、正規表現置換を実行します。
<code class="language-csharp">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)); }</code>
この機能を利用するには:
StackOverflow.dll
アセンブリにコンパイルします。CREATE ASSEMBLY
を使用して SQL Server データベース内にアセンブリを登録します。CREATE FUNCTION
を使用して SQL CLR 関数を作成します。使用例:
<code class="language-sql">SELECT [dbo].[StackOverflowRegexReplace] ('Hello Kitty Essential Accessory Kit', '[^\u0000-\u007F]', '') -- Result: Hello Kitty Essential Accessory Kit</code>
これらのメソッドは、SQL Server の varchar 列から非標準文字を効果的にクレンジングし、データの整合性を向上させ、潜在的な問題を防ぎます。
以上がC# と SQL CLR を使用して SQL Server の varchar 列から奇妙な文字を削除する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。