由於數據庫的一個表字段中多包含html標簽,現在需要修改數據庫的字段把html標簽都替換掉。當然我可以通過寫一個程序去修改,那畢竟有點麻煩。直接在查詢分析器中執行,但是MS SQL Server並沒有提供正則表達式,替換html標簽可不那么容易。我們可以通過CLR托管來實現一個通過正則表達式來替換html標簽的自定義函數。(注:SQL CLR只能在MS SQL Server 2005或以上版本中適用)
第一步:通過Visual Studio 2008新建一個SQL Server項目
第二步:配置連接的數據庫
點擊上一步確定后,出現如下提示框
可以通過 添加新引用 來添加一個數據庫連接(只適用MS SQL Server 2005或以上版本,再次提醒哦),添加以后選擇其中一個數據庫點擊確定。
第三步:添加一個自定義函數
然后編寫自定義函數的類(需要注意的是類的方法必須是靜態的)
using System;
using System.Data;
using System.Data.SqlClient;
using System.Data.SqlTypes;
using Microsoft.SqlServer.Server;
using System.Text.RegularExpressions;
public partial class UserDefinedFunctions
{
public static readonly RegexOptions Options = RegexOptions.IgnorePatternWhitespace | RegexOptions.Singleline;
[Microsoft.SqlServer.Server.SqlFunction]
public static SqlString RegexReplace(SqlChars input, SqlString pattern, SqlString replace)
{
Regex regex = new Regex(pattern.Value, Options);
return regex.Replace(new string(input.Value), replace.Value);
}
};
第四步:部署,類編寫完成后進行部署
部署了以后,你指定的連接數據庫下面會生成一個自定義函數和一個程序集(如圖)
然后就可以調用自定義函數了,不過調用自定義函數前,你還得啟用一些配置
EXEC sp_configure 'allow updates',0
EXEC sp_configure 'show advanced options', 1 -- make them available
reconfigure
EXEC sp_configure 'clr enabled', 1 -- turn on OLE
reconfigure
啟用這些配置后,你就可以調用剛剛自定義的函數了.
調用
select dbo.RegexReplace('<p>aaa</p>','<(.[^>]*)>','')
結果為:aaa