提取sql连接字符串的属性

本文关键字:属性 字符串 连接 sql 提取 | 更新日期: 2024-09-23 02:11:01

我想从connectionString(字符串变量)中提取服务器和数据库的名称。服务器和数据库的名称随着我们从DEV转移到STAGE,然后再转移到PROD而更改。

下面是一个例子:

Data Source=SERVER_XYZ;Initial Catalog=DATABASE_XYZ;User ID=us;Password=pass
Data Source=SERVER_XYZPQR;Initial Catalog=DATABASE_XYZPQR;User ID=us;Password=pass

请注意名称的更改(以及整个字符串的长度)

如何在不知道长度的情况下捕获数据源和初始目录?因此,在表单加载时,它将获得Server&要显示给用户的数据库名称(这样他/她就可以看到他/她连接到哪个服务器和数据库?

提取sql连接字符串的属性

您可以使用连接字符串生成器类,该类一旦构建就具有数据源和初始目录属性

http://msdn.microsoft.com/en-us/library/system.data.sqlclient.sqlconnectionstringbuilder.aspx

string connStr = "Data Source=SERVERx;Initial Catalog=DBx;User ID=u;Password=p"; 
var csb = new SqlConnectionStringBuilder(connStr);
string dataSource = csb.DataSource;
string initialCatalog = csb.InitialCatalog;

让.net框架为您完成工作;)不干扰子字符串或正则表达式

C#Regex解决方案:

String input = "Data Source=SERVER_XYZ;Initial Catalog=DATABASE_XYZ;User ID=us;Password=pass";
// Match the server:
Match serverMatch = Regex.Match(input, @"Source=([A-Za-z0-9_.]+)", RegexOptions.IgnoreCase);
// Match the database:
Match databaseMatch = Regex.Match(input, @"Catalog=([A-Za-z0-9_]+)", RegexOptions.IgnoreCase);
// Get the string
if (serverMatch.Success)
{
  String server = serverMatch.Groups[1].Value;
}

记住URL的有效字符:

ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-._~:/?#[]@!$&'()*+,;=