编程语言
首页 > 编程语言> > c# – 为什么在DataSource中返回String.Length而不是实际值

c# – 为什么在DataSource中返回String.Length而不是实际值

作者:互联网

我有这个代码,它构建了一个IList< string>:

IList<string> databases;

using (MySqlConnection _conn = Session.Connection)
using (MySqlCommand _cmd = _conn.CreateCommand("SHOW databases"))
{
    _cmd.Connection.Open ( );
    var _dr = _cmd.ExecuteReader();

    databases = new List<string> ( _dr.SelectFromReader ( reader =>
        reader[ 0 ] is DBNull ? null : reader[ 0 ].ToString ( ) ) );

    _cmd.Connection.Close ( );
}

dgrid_Main.DataSource = databases;

遵循扩展方法SelectFromReader here的工作方式.

问题是,为什么dgrid_Main显示每个数据库的长度……

……而不是名字?我跑了这个测试:

foreach (string db in databases)
{
    //  winform treeview control
    trv_ServerObjects.Nodes.Add ( db );
}

…我得到以下结果:

解决方法:

因为dgrid_Main上的DataSource属性将绑定集合中对象的每个公共属性,而不是它自己的对象.而Length是字符串对象的一个​​公共属性.

当您实际遍历IList时,您将获得数据库名称列表.

试试这个..

dgrid_Main.DataSource = databases.ToList().Select(db => new { db });

标签:c,datasource,datagridview,ilist
来源: https://codeday.me/bug/20190626/1295909.html