【问题标题】:VB.NET evaluate exception when filtering DataGridView using a Combobox and a TextboxVB.NET 在使用组合框和文本框过滤 DataGridView 时评估异常
【发布时间】:2012-10-27 05:50:15
【问题描述】:

我正在尝试使用组合框搜索我的 DGV,以获取搜索查询的列名称和文本框。我以前用过这段代码,它工作了,但现在我得到一个EvaluateException

无法对 System.Double 和 System.String 执行“点赞”操作。

这就是我正在做的事情:

Dim dv As DataView = New DataView()
Dim CmSi = cmbSearch.SelectedItem
dv.Table = OutGoingDataSet.outgoingdeliveries
dv.RowFilter = CmSi & " Like '" & txtSearch.Text & "'"
OutgoingDataGridView.DataSource = dv

我该如何解决这个问题?

【问题讨论】:

  • cmbSearch.SelectedItem 中值的数据类型是什么?
  • @AhmadAl-Mutawa 列的名称。分别是TransactionNumberPosted
  • 你真的应该考虑将选项严格打开...
  • @WozzeC 对不起,我还在学习,但什么是 Option Strict?
  • @AlexLuthor Option strict 基本上会强制您正确编写代码。例如,您有 Dim CmSi 并将其用作字符串。但它实际上是一个组合框项目。你的代码可以工作,因为 strict off 是一个快乐的人,并且使用 items tostring 函数,而你可以很高兴地无知。选项 strict 强制您将所选项目转换为字符串,否则会标记错误。因此,您将始终知道 CmSi 将是一个字符串。

标签: vb.net winforms visual-studio-2010 datagridview


【解决方案1】:

这是你的问题。当您应用过滤器时,您会执行以下检查:

Column LIKE 'String'. 

这适用于所有包含字符串的列。双打不起作用,因为它们不是字符串。基本上这就像

if (5 == "5") 

这当然是假的。

因此,在进行LIKE 比较之前,您必须将双精度转换为字符串。我不知道它是否会起作用,但我认为它会。

dv.RowFilter = "CONVERT(" & CmSi & ", System.String) LIKE '" & txtSearch.Text & "'"

【讨论】:

  • 是的,我知道这是问题所在,但我尝试了转换,也许我用错了。我会尝试使用您的样品...非常感谢。 :D
  • 谢谢你,它工作得很好......我确实用错了。我所做的是“转换 System.String(Query)”。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2016-04-05
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多