微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

vb.net CheckedListbox 从数据库中获取值

如何解决vb.net CheckedListbox 从数据库中获取值

我正在从 MsAccess 数据库表中填充 CheckedListBox。该表由两个字段组成,Terms 和 RegX。我想显示条款,但当我提交时,我想从 RegX 字段中获取值。

Public Function GetMyTable() As DataTable
        ' Create new DataTable instance.
        Dim table As New DataTable

        Dim strsql As String = "SELECT * FROM Keywords ORDER BY Terms ASC"

        Dim cmd As New OleDbCommand(strsql,con)
        Using dr As OleDbDataReader = cmd.ExecuteReader
            table.Load(dr)
        End Using

        Return table
    End Function

Private Sub SearchInDoc_Load(sender As Object,e As EventArgs) Handles MyBase.Load

        Dim dt1 As DataTable = GetMyTable()

        If dt1.Rows.Count > 0 Then
            For i As Integer = 0 To dt1.Rows.Count - 1
                CheckedListBox1.Items.Add(CStr(dt1.Rows(i).Item("Terms")),False)
            Next
        End If
        CheckedListBox1.CheckOnClick = True
    End Sub

当我点击我的提交按钮时,我不知道如何返回 RegX 的值

解决方法

如果您想将有关“Terms”和“RegX”的信息保存在一起,那么您应该使用 CheckedListBox 的 DataSource 属性将其设置为检索到的数据表,然后指定应在列表中显示的列。

Private Sub SearchInDoc_Load(sender As Object,e As EventArgs) Handles MyBase.Load

    Dim dt1 As DataTable = GetMyTable()
    CheckedListBox1.DataSource = dt1
    CheckedListBox1.DisplayMember = "Terms"
    CheckedListBox1.CheckOnClick = True
End Sub

现在在您的提交按钮中,您可以添加这样的代码来检索 RegX 字段

Sub Submit_Click(sender As Object,e As EventArgs) Handles Submit.Click
    For Each row As DataRowView In CheckedListBox1.CheckedItems
        Console.WriteLine(row("RegX"))
    Next
End Sub

CheckedListBox 中的每个元素都是从表中提取的 DataRowView,您可以提取有关 RegX 字段的信息,只需使用列名索引该 DataRowView。
在上面的示例中,只有选中的项目受循环枚举的约束。如果要遍历 CheckedListBox 中的所有项目,请使用 CheckedListBox1.Items

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。