如何将DataTable的特定列绑定到DataGridView?

15

我的DataTable从数据库中获取了三列,但我只需要将其中两列绑定到DataGridView上。能否请你帮助我完成这个操作呢?


asp.net winforms?请指定框架和/或语言。 - naveen
7个回答

29

自己创建DataGridView的列。可以尝试以下代码。

DataGridView dataGridView1 = new DataGridView();
BindingSource bindingSource1 = new BindingSource();

dataGridView1.ColumnCount = 2;

dataGridView1.Columns[0].Name = "Field1";
dataGridView1.Columns[0].DataPropertyName = "Field1";
dataGridView1.Columns[1].Name = "Field2";
dataGridView1.Columns[1].DataPropertyName = "Field2";

bindingSource1.DataSource = GetDataTable();
dataGridView1.DataSource = bindingSource1;

21

按照上面回答的方法添加该列,并不要忘记设置:

dataGridView1.AutoGenerateColumns = false;

奇怪的是,AutoGenerateColumns 在我的智能感知中似乎没有出现。当我只是键入 dataGridView1.AutoGenerateColumns=false 时,它按预期工作,但令人困惑的是它没有显示出来。 - AndyD273
我按照这个问题上的说明来使datagridview与intellisense正常工作:https://stackoverflow.com/questions/43603438/incomplete-list-of-properties-methods-in-intellisense - AndyD273

3

这个问题在一段时间前就有人问过了,所以你可能不需要这个答案……但希望其他人会觉得有用。

我曾经遇到类似的情况,最简单的解决方法是创建数据表的临时副本,然后直接删除需要去除的列。例如:

DataTable temp = YourDataTable;
temp.Columns.Remove(temp.Columns[2]) // Will remove the third column for example
YourDataTable.DataSource = temp;
YourDataTable.DataBind();

我认为这应该能解决问题!
祝好!

3
private void Form1_Load(object sender, EventArgs e)
    {
        SqlConnection con = new SqlConnection("connection string");
        SqlDataAdapter adp = new SqlDataAdapter("select  Fieldname1,fieldname2 from Table Name", con);
        DataSet ds = new DataSet();
        ds.Clear();
        adp.Fill(ds);
        if (ds.Tables[0].Rows.Count > 0)
        {
            dataGridView1.DataSource = ds.Tables[0];
  }

肯定会有效。

2
我们可以使用所需的列创建一个新的 DataTable,并从数据集中添加行。然后,我们可以使用新创建的 DataTable 初始化 DataGrid。
dt = new DataTable();          
dt_Property.Columns.Add("Field1");
dt_Property.Columns.Add("Field2");
int i = 0;
DataRow row = null;
foreach (DataRow r in ds.Tables[0].Rows)
{               
    row = dt.NewRow();                    
    row["Field1"] = ds.Tables[0].Rows[i][1];
    row["Field2"] = ds.Tables[0].Rows[i][2];
    dt_Property.Rows.Add(row);   
    i = i + 1;
}

dataGridView1.DataSource = dt;

1
将DataTable绑定到DataGridView,然后隐藏您不想要的列。
dataGridView1.DataSource = datatable;
dataGridView1.Columns["ColumnName"].Visible = false;

1
这可能会有用。
DataSet ds = new DataSet(); <-- Get data from Database here
DataTable dt = ds.Tables[0];
DataView view = new DataView(dt);
DataTable resultTable = view.ToTable(false, "Column1", 
"Column2","Column3","Column4","Column5","Column6");
dataGridView.DataSource = resultTable ;

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接