峰峦@叠嶂 2023-02-28 19:03 采纳率: 97.6%
浏览 37
已结题

如何能去除下拉列表里面的重复值

请问一下,我的form_load里面,写了连接数据库设备表的代码,用于实现一启动,下拉表combobox即连接设备所属的车间名称,但该列所属的车间名称有很多重复值,请问怎么能去除这些个重复值呢,并实现按下拉表的车间名称,查询该车间内的设备信息,相关截图与部分form_load的代码如下;

img


```c#

            SqlDataAdapter sda = new SqlDataAdapter();

            DataSet ds = new DataSet();

            DataTable dt = new DataTable();

            //声明一个SQLcommand对象

            SqlCommand sqlcmd = new SqlCommand("SELECT * FROM b_EquipmentInfo", conn);


            //执行查询语句
            sda.SelectCommand = sqlcmd;


            //调用DataAdapter对象的Fill()方法来填充数据集
            sda.Fill(ds, "b_EquipmentInfo");


            //绑定combobox的数据集
            combobox1DataTable.DataSource = ds.Tables["b_EquipmentInfo"];

            //选定combobox显示的成员及将Name这一列显示在combobox中
            combobox1DataTable.DisplayMember = "Plinename";

            //combobox的实际取值
            combobox1DataTable.ValueMember = "Plinecode";

以下是点击查询按钮的代码;

```c#
   conn = new SqlConnection("server=ip;database=db;user=sa;password=1123");

               conn.Open();

               //查询条件      
               SqlString = "select EquipmentCode,EquipmentName,EquipmentType,EquipmentAddress,Manufacturer,PlineName,EquipmentState from b_EquipmentInfo where PlineName = '" + combobox1DataTable.Text + "' "; //配置了与下拉列表绑定,按其查询分类显示;
               //加载数据并显示
               try
               {
                   //查询条件和SqlConnection连接
                   SqlCommand cmd = new SqlCommand(SqlString, conn);
                   //数据适配器
                   SqlDataAdapter sda = new SqlDataAdapter();
                   sda.SelectCommand = cmd;
                   //DataTable存储数据
                   DataTable dt = new DataTable();
                   sda.Fill(dt);
                   dataGridView1.DataSource = dt;
               }
               catch
               { }
               finally
               {
                   conn.Close();

  • 写回答

3条回答 默认 最新

  • 峰峦@叠嶂 2023-03-01 08:15
    关注

    若改为去重语句后“SELECT distinct Plinename FROM b_EquipmentInfo”,其的错误提示如下:在 System.Windows.Forms.NativeWindow.DebuggableCallback(IntPtr hWnd, Int32 msg, IntPtr wparam, IntPtr lparam)
    InnerException:

    该错误提示,对应是这条语句 combobox1DataTable.ValueMember = "Plinecode",请问如何处理呢,再指导一下,谢谢;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 3月9日
  • 已采纳回答 3月1日
  • 修改了问题 2月28日
  • 修改了问题 2月28日
  • 展开全部

悬赏问题

  • ¥15 对于这个复杂问题的解释说明
  • ¥50 三种调度算法报错 采用的你的方案
  • ¥15 关于#python#的问题,请各位专家解答!
  • ¥200 询问:python实现大地主题正反算的程序设计,有偿
  • ¥15 smptlib使用465端口发送邮件失败
  • ¥200 总是报错,能帮助用python实现程序实现高斯正反算吗?有偿
  • ¥15 对于squad数据集的基于bert模型的微调
  • ¥15 为什么我运行这个网络会出现以下报错?CRNN神经网络
  • ¥20 steam下载游戏占用内存
  • ¥15 CST保存项目时失败