vb.net – 如何选择绑定到DataTable的Datagridview中的可见列
我在Customer DataTable上有以下字段:ID,标题,名称,地址,电子邮件,传真以及绑定DataGridView的此代码:
Dim sql As String = "SELECT * FROM Customers" Dim daHeader As New SqlDataAdapter(sql,Conn) daHeader.Fill(dsNota,"Customers") dgvHeader.DataSource = dsNota.Tables("Customers") 如何在不更改SQL字符串的情况下查看DataGridView中的标题,地址数据: "SELECT title,Name,Addrs FROM Customer"
因此,如果您不想修改查询字符串(因为@Neolisk注意到这通常是使用Select *的一个不好的做法,但这是另一个争议),因此您获得的列数多于您想要显示的列数:
Solution1(理想情况下,如果数据表中有很多列,并且您只想显示其中的一些列) >您需要将AutoGenerateColumns属性设置为false. 所以代码是: dgvheader.AutoGenerateColumns = False dgvHeader.Columns.Add(New DataGridViewTextBoxColumn() With {.HeaderText = "Title",.DataPropertyName = "title"}) dgvHeader.Columns.Add(New DataGridViewTextBoxColumn() With {.HeaderText = "Name",.DataPropertyName = "Name"}) dgvHeader.Columns.Add(New DataGridViewTextBoxColumn() With {.HeaderText = "Adresse",.DataPropertyName = "Addrs"}) dgvHeader.DataSource = dsNota.Tables("Customers") 解决方案2(理想情况下,并且您希望隐藏其中的一些列,那么您希望保留AutoGenerateColumns的优势) >将AutoGenerateColumns属性设置为true(或者从那以后什么都不做 Private Sub dataGridView1_DataBindingComplete(ByVal sender As Object,ByVal e As DataGridViewBindingCompleteEventArgs) Handles dgvHeader.DataBindingComplete With dgvHeader .Columns("Fax").Visible = False End With End Sub (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |