Foxtable(狐表)用户栏目专家坐堂 → 控件上是字符数组,如何实现筛选加载


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

主题:控件上是字符数组,如何实现筛选加载

美女呀,离线,留言给我吧!
采菊东篱下
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:1882 积分:10385 威望:0 精华:0 注册:2019/4/6 8:45:00
控件上是字符数组,如何实现筛选加载  发帖心情 Post By:2022/8/12 20:35:00 [只看该作者]

无法上传图片,只能手动输入:
ComboBox1控件上的效果是这样的,要实现筛选加载:
月租停车
月租停车-业主月租停车
月租停车-租户月租停车
月租停车-外来月租停车
临时停车
临时停车-亲情临时停车
临时停车-外来临时停车
铺位租金
广告或其他

这样写只实现到一级筛选,无法实现二级筛选:
Dim Filter As String
With e.Form.Controls("ComboBox1")
    If .Value IsNot Nothing Then
        Dim Parts() As String = .Value.Split("-")
        If Parts(0) IsNot Nothing Then
            Filter = "分类 = '" & Parts(0) & "'"
        ElseIf Parts(1) IsNot Nothing Then
            If Filter > "" Then
                Filter = Filter & " Or "
            End If
            Filter = Filter & "明细分类 = '" & Parts(1) & "'"
        End If
    End If
End With
With e.Form.Controls("DateTimePicker1")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "Year(日期) = '" & Year(.Value) & "'And Month(日期) = '" & Month(.Value) & "'"
    End If
End With
With e.Form.Controls("DropBox1")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "车牌号码 = '" & .Value & "'"
    End If
End With
With DataTables("安缴费日期查询_Table1")
    If Filter > "" Then
        LockBaseMainForm() '锁定主界面
        .StopRedraw()
        .LoadFilter = Filter
        .LoadOrder = "日期,单号,[_SortKey] DESC"
        For i As Integer = DataTables("缴费情况").DataRows.count - 1 To 0 Step -1
            Dim tr As DataRow = DataTables("缴费情况").DataRows(i)
            If tr.IsNull("日期") Then
                tr.delete
            End If
        Next
        .Load()
        .ResumeRedraw()
        UnLockBaseMainForm() '解锁主界面
    End If
    If .DataRows.Count < 15 Then
        .AddNew(15 - .DataRows.Count)
    End If
End With
[此贴子已经被作者于2022/8/12 20:50:03编辑过]

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


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/8/13 9:26:00 [只看该作者]

Dim Filter As String
With e.Form.Controls("ComboBox1")
    If .Value IsNot Nothing Then
        Dim Parts() As String = .Value.Split("-")
Filter = "分类 = '" & Parts(0) & "'"
        If Parts.length > 1 Then
            Filter = "(" & Filter & " or 明细分类 = '" & Parts(1) & "')"
        End If
    End If
End With

 回到顶部
美女呀,离线,留言给我吧!
采菊东篱下
  3楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:1882 积分:10385 威望:0 精华:0 注册:2019/4/6 8:45:00
  发帖心情 Post By:2022/8/13 10:09:00 [只看该作者]

不行依然只加载到一级筛选数,如果改为如下,则完全没加载数据:
Dim Filter As String
With e.Form.Controls("ComboBox1")
    If .Value IsNot Nothing Then
        Dim Parts() As String = .Value.Split("-")
        Filter = "分类 = '" & Parts(0) & "'"
        If Parts.length > 1 Then
            Filter = "(" & Filter & " And 明细分类 = '" & Parts(1) & "')"
        End If
    End If
End With
With e.Form.Controls("DateTimePicker1")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "Year(日期) = '" & Year(.Value) & "'And Month(日期) = '" & Month(.Value) & "'"
    End If
End With
With e.Form.Controls("DropBox1")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "车牌号码 = '" & .Value & "'"
    End If
End With
With DataTables("安缴费日期查询_Table1")
    If Filter > "" Then
        LockBaseMainForm() '锁定主界面
        .StopRedraw()
        .LoadFilter = Filter
        .LoadOrder = "日期,单号,[_SortKey] DESC"
        For i As Integer = DataTables("缴费情况").DataRows.count - 1 To 0 Step -1
            Dim tr As DataRow = DataTables("缴费情况").DataRows(i)
            If tr.IsNull("日期") Then
                tr.delete
            End If
        Next
        .Load()
        .ResumeRedraw()
        UnLockBaseMainForm() '解锁主界面
    End If
    If .DataRows.Count < 15 Then
        .AddNew(15 - .DataRows.Count)
    End If
End With
[此贴子已经被作者于2022/8/13 10:11:18编辑过]

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


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/8/13 10:16:00 [只看该作者]

没有符合条件的数据

msgbox(Filter)

 回到顶部
美女呀,离线,留言给我吧!
采菊东篱下
  5楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:1882 积分:10385 威望:0 精华:0 注册:2019/4/6 8:45:00
  发帖心情 Post By:2022/8/13 11:30:00 [只看该作者]

弹出:
(分类= '月租停车' And 明细分类 = '业主月租停车') And Year(日期)='2020' And Month(日期) = '12'
表里一定有当期数据的。

 回到顶部
美女呀,离线,留言给我吧!
采菊东篱下
  6楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:1882 积分:10385 威望:0 精华:0 注册:2019/4/6 8:45:00
  发帖心情 Post By:2022/8/13 12:05:00 [只看该作者]

改为这样还是没任何数据显示:
Dim Filter As String
With e.Form.Controls("ComboBox1")
    If .Value IsNot Nothing Then
        Dim Parts() As String = .Value.Split("-")
        Filter = "分类 = '" & Parts(0) & "'"
        If Parts.length > 1 Then
            Filter = Filter & " And 明细分类 = '" & Parts(1) & "'"
        End If
    End If
End With
With e.Form.Controls("DateTimePicker1")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "Year(日期) = " & Year(.Value) & " And Month(日期) = " & Month(.Value)
    End If
End With
With e.Form.Controls("DropBox1")
    If .Value IsNot Nothing Then
        If Filter > "" Then
            Filter = Filter & " And "
        End If
        Filter = Filter & "车牌号码 = '" & .Value & "'"
    End If
End With
msgbox(Filter)
With DataTables("安缴费日期查询_Table1")
    If Filter > "" Then
        LockBaseMainForm() '锁定主界面
        .StopRedraw()
        .LoadFilter = Filter
        .LoadOrder = "日期,单号,[_SortKey] DESC"
        For i As Integer = DataTables("缴费情况").DataRows.count - 1 To 0 Step -1
            Dim tr As DataRow = DataTables("缴费情况").DataRows(i)
            If tr.IsNull("日期") Then
                tr.delete
            End If
        Next
        .Load()
        .ResumeRedraw()
        UnLockBaseMainForm() '解锁主界面
    End If
    If .DataRows.Count < 15 Then
        .AddNew(15 - .DataRows.Count)
    End If
End With

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


加好友 发短信
等级:超级版主 帖子:111393 积分:567029 威望:0 精华:9 注册:2015/6/24 9:21:00
  发帖心情 Post By:2022/8/13 14:13:00 [只看该作者]

肯定没有符合这个条件的数据

 回到顶部
美女呀,离线,留言给我吧!
采菊东篱下
  8楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:1882 积分:10385 威望:0 精华:0 注册:2019/4/6 8:45:00
  发帖心情 Post By:2022/8/13 14:42:00 [只看该作者]

有:
     日期         分类        明细分类     用户性质   序号   巷  号   房   姓名  固定电话   手机号码       车牌号码         前缀           单号              起计时间        止计时间   缴费月数   月租单价   缴费金额       
2020-12-23 月租停车 业主月租停车   业主  8   八巷  5   607  李生  2222222  12345678911  粤JB8888W YZ   YZ-202012-00005   2021-01-01 2021-03 - 31 3 80 240

 回到顶部
美女呀,离线,留言给我吧!
采菊东篱下
  9楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:1882 积分:10385 威望:0 精华:0 注册:2019/4/6 8:45:00
  发帖心情 Post By:2022/8/13 14:44:00 [只看该作者]

图片点击可在新窗口打开查看,你们的论坛复制上来的数据全乱了,图片也不让上传!

 回到顶部
美女呀,离线,留言给我吧!
采菊东篱下
  10楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:八尾狐 帖子:1882 积分:10385 威望:0 精华:0 注册:2019/4/6 8:45:00
  发帖心情 Post By:2022/8/13 14:46:00 [只看该作者]

下面的数据是同一行的,没法编辑!乱!你点编辑看吧,编辑分两行,发出后变成这样!图片点击可在新窗口打开查看

 回到顶部
总数 14 1 2 下一页