我有一个连接字符串,我希望能够窥视例如“数据源”。 是否有解析器,或者我必须搜索字符串?
当前回答
所以我发现所有现有的答案或多或少都是错误的。我最终得到了以下简单的解决方案:
class ConnectionStringParser: DbConnectionStringBuilder {
ConnectionStringParser(string c) { Connection = c; }
public override bool ShouldSerialize(string keyword) => true;
}
解析器在DbConnectionStringBuilder中,非常容易获取。我们必须做的唯一愚蠢的事情是将ShouldSerialize设置为总是返回true,以防止在尝试往返任意连接字符串时丢失组件。
其他回答
是的,有system。data。common。dbconnectionstringbuilder类。
DbConnectionStringBuilder类 类的基类 强类型的连接字符串 建筑商(SqlConnectionStringBuilder OleDbConnectionStringBuilder,等等 )获得。连接字符串 构建者让开发人员 以编程方式创建语法 正确连接字符串,并进行解析 并重建现有连接 字符串。
感兴趣的子类是:
System.Data.EntityClient.EntityConnectionStringBuilder
System.Data.Odbc.OdbcConnectionStringBuilder
System.Data.OleDb.OleDbConnectionStringBuilder
System.Data.OracleClient.OracleConnectionStringBuilder
System.Data.SqlClient.SqlConnectionStringBuilder
例如,要从SQL-server连接字符串中“窥视数据源”,你可以这样做:
var builder = new SqlConnectionStringBuilder(connectionString);
var dataSource = builder.DataSource;
使用SqlConnectionStringBuilder 不幸的是,由于连接字符串不同,您将不得不使用特定于DB的ConnectionStringBuilder。
你想要使用DbProviderFactory。CreateConnectionStringBuilder(),它为您提供特定于连接器的连接字符串构建器/解析器,但不要求您使用任何特定于连接器的类。
所以我发现所有现有的答案或多或少都是错误的。我最终得到了以下简单的解决方案:
class ConnectionStringParser: DbConnectionStringBuilder {
ConnectionStringParser(string c) { Connection = c; }
public override bool ShouldSerialize(string keyword) => true;
}
解析器在DbConnectionStringBuilder中,非常容易获取。我们必须做的唯一愚蠢的事情是将ShouldSerialize设置为总是返回true,以防止在尝试往返任意连接字符串时丢失组件。
我不太喜欢这里所有的答案。这就是我的发现。
使用。net Core
你可以直接使用内置的DbConnectionStringBuilder:
var builder = new System.Data.Common.DbConnectionStringBuilder();
builder.ConnectionString = "server=localhost;login=sa;pass=awesomeness";
var server = builder["server"];
var login = builder["login"];
var pass = builder["pass"];
推荐文章
- 实体框架核心:在上一个操作完成之前,在此上下文中开始的第二个操作
- 如何为构造函数定制Visual Studio的私有字段生成快捷方式?
- 为什么Visual Studio 2015/2017/2019测试运行器没有发现我的xUnit v2测试
- 如何使用JSON确保字符串是有效的JSON。网
- AppSettings从.config文件中获取值
- 通过HttpClient向REST API发布一个空体
- 如何检查IEnumerable是否为空或空?
- 自动化invokerrequired代码模式
- 没有ListBox。SelectionMode="None",是否有其他方法禁用列表框中的选择?
- 在c#代码中设置WPF文本框的背景颜色
- 在c#中,什么是单子?
- c#和Java中的泛型有什么不同?和模板在c++ ?
- c#线程安全快速(est)计数器
- 如何将此foreach代码转换为Parallel.ForEach?
- 如何在iis7应用程序池中设置。net Framework 4.5版本