如何在实现IDictionary和ICollection的类的实例上在Powershell中设置属性

 左右印象摄影 发布于 2023-02-13 18:06

我正在尝试使用此处SQLiteConnectionStringBuilder的ADO.NET SQLite数据提供程序库中的类.类定义有一个名为DataSource的属性.

public sealed class SQLiteConnectionStringBuilder : DbConnectionStringBuilder
{
    public SQLiteConnectionStringBuilder();
    public SQLiteConnectionStringBuilder(string connectionString);

    public string DataSource { get; set; }
}

我试图在我的powershell脚本中设置,即:

$csb = new-object -TypeName System.Data.SQLite.SQLiteConnectionStringBuilder 
$csb.DataSource = "C:\data\mydb.db";

我遇到的问题是SQLiteConnectionStringBuilderDbConnectionStringBuilder哪个继承实现以下接口

public class DbConnectionStringBuilder : IDictionary, ICollection, IEnumerable, ....

因为类实现了这些接口,所以Powershell不会在类上设置属性DataSource,而是将其$csb视为哈希表并向其添加键值对,即key="DataSource", value="C:\data\mydb.db".不用说这不是我想要的.那我现在该怎么办?如何强制Powershell设置属性而不将$ csb视为哈希表?谢谢!

1 个回答
  • 如果您在创建对象时尝试设置此项,则可以使用以下Property参数New-Object:

    $csb = New-Object -TypeName System.Data.SQLite.SQLiteConnectionStringBuilder -Property @{ DataSource = "C:\data\mydb.db" }
    

    但是,如果您尝试稍后设置该属性,我发现的唯一方法是使用.NET Reflection API有点笨拙:

    $csb.GetType().GetProperty("DataSource").SetValue($csb, "C:\data\mydb.db")
    

    2023-02-13 18:09 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有