ListBox的多个选定值作为SELECT SQL查询的参数

问题描述 投票:2回答:3

我想将ListBox中的多个选定值作为参数传递给我的Select SQL Query。

我使用的是VB.NET,我怎么能实现这个呢?...

sql select listbox selected
3个回答
0
投票

可能最好的方法是迭代列表框并仅获取所选项目。假设您使用的是Web表单,以下是一个示例:

For Each myItem As ListItem In myListBox.Items
    If myItem.Selected Then
        'Add the item to the list of parameters
    End If
Next

0
投票

通过迭代列表框项目来选择您的项目,并将它们添加到某种类型的集合中并传递它们。

For i = 0 To ListBox1.Items.Count - 1
   If ListBox1.Items(i).Selected Then
       ' Add to collection
   End If
Next

在这种情况下,将SQL语句包装在存储过程中可能是个好主意,因为它会为您提供发送参数的灵活性。

我所看到的另一个技巧是,当人们根据选择有不同数量的参数时,会将选择附加到一个始终为真的条件,如:

Base SQL = Select * From MyTable,其中1 = 1

然后根据列表项(集合),您可以选择性地“添加”Ands


0
投票

将选择模式设置为SelectionMode.MultiExtended或SelectionMode.MultiSimple。使用SelectedItems属性。

UPDATE

我不知道你的select语句是什么,所以在C#中(抱歉没有VB)

string sql = "select [columns] from [table] where [column] in (";
string delimiter = ",";
foreach(var selected in lb1.SelectedItems)
{
  sql = String.Concat(sql, selected.text, delimiter);
}
sql = sql.Substring(0, sql.Length-1);
sql = String.Concat(sql, @");");
© www.soinside.com 2019 - 2024. All rights reserved.