Foxtable(狐表)用户栏目专家坐堂 → 模糊搜索语句改造


  共有2439人关注过本帖树形打印复制链接

主题:模糊搜索语句改造

帅哥哟,离线,有人找我吗?
supwork
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:688 积分:4903 威望:0 精华:0 注册:2013/10/27 17:14:00
模糊搜索语句改造  发帖心情 Post By:2015/7/9 18:27:00 [只看该作者]

Dim tb As Table = e.Form.Controls("Table1").Table
Dim sf As String =e.Form.Controls("模糊查找").text
Dim str As String = ""
Dim cmbCols As WinForm.ComboBox = e.Form.Controls("cmbCols")
If e.Sender.Text.Length>0 Then
    If cmbCols.Text.length>0 Then
        If tb.Cols(cmbCols.Text).IsString Then
            str= cmbCols.Text & " Like '%" & e.Sender.Text & "%'"
        Else
            str = " convert(" & cmbCols.Text & ",'System.String') Like '%" & e.sender.Text & "%'"
         End If
    Else
        For Each dc As Col In tb.Cols
            If dc.Visible=True And dc.IsString Then
                str= str & iif(str.Length>0," Or ","") & dc.Name & " Like '%" & e.Sender.Text & "%'"
            End If
        Next
    End If
Else
    str=""
End If

 

以上语句能实现模糊搜索比如 e.sender.Text  的值为7A是可搜索出文本字段中的包含 7A连续字符串的数据

 

现要实现 输入,7空格A进行搜索,以上代码搜索7空格A三字符连续的结果。 需求是搜索到的结果要 *7*A*,即字符串中含 有7,A的即行,7与A之间可以0个或N多个字符

代码 如何写,数据源为SQL型


 回到顶部
帅哥哟,离线,有人找我吗?
supwork
  2楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:688 积分:4903 威望:0 精华:0 注册:2013/10/27 17:14:00
  发帖心情 Post By:2015/7/9 18:58:00 [只看该作者]

 

型号 Like 'A[*]%'

 

关键是官方 帮助里的这代码测试 无效


 回到顶部
帅哥哟,离线,有人找我吗?
大红袍
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:贵宾 帖子:39310 积分:196782 威望:0 精华:1 注册:2015/4/25 9:23:00
  发帖心情 Post By:2015/7/9 19:14:00 [只看该作者]

 测试了一下,中间匹配的情况,无法直接用filter得到。

 

 必须循环判断每一个单元格的值,看是否符合,符合就记录主键的字,最后filter


 回到顶部
帅哥哟,离线,有人找我吗?
supwork
  4楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:三尾狐 帖子:688 积分:4903 威望:0 精华:0 注册:2013/10/27 17:14:00
  发帖心情 Post By:2015/7/12 23:06:00 [只看该作者]

经测试在SQL中字符中间可以支持使用%通配符号

 

SELE CT *
FROM 物料表 WHERE (规格 LIKE '%D%P%L%')

 

但是在狐表中就不行

 

希望官方也能支持这种查询方法


 回到顶部