Foxtable(狐表)用户栏目专家坐堂 → [求助]从后台(外部数据源)筛选记录


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

主题:[求助]从后台(外部数据源)筛选记录

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


加好友 发短信
等级:幼狐 帖子:141 积分:904 威望:0 精华:0 注册:2016/8/4 10:50:00
[求助]从后台(外部数据源)筛选记录  发帖心情 Post By:2016/10/23 17:17:00 [只看该作者]

怎样改这段代码

Dim dr1 As DataRow = DataTables("T246").SQLFind("[F4411] Is Not Null", "F4411", 0)
Dim dr2 As DataRow = DataTables("T246").SQLFind("[F4411] Is Not Null", "F4411 Desc",0)
If dr1 Is Nothing OrElse dr2 Is Nothing Then Return
Dim d1 As Date
Dim d2 As Date
Dim drl0 As DataRow
Dim dt1 As Date =dr1("F4411")
Dim dt2 As Date =dr2("F4411")
Dim val1 As New List (of String)
val1= DataTables("T246").GetValues("F4386")
Dim d As Integer = dt2.Year -dt1.Year
Dim j As Integer = 0
Dim drl As New List (of DataRow)
For i As Integer = 0 To d
    d1 = New Date(dt1.Year+i-1,11,5) '取得该年的第一天
    d2 = new Date(dt1.Year+i,11,5) '取得该年的最后一天
    For Each val As String In val1
        drl0 = DataTables("T246").Find("[F4411] >= #" & d1 & "# And [F4411] <= #" & d2 & "# And [F4386] ='" & val & "'","F4411 Desc",0)
        If drl0 IsNot Nothing Then
            drl.add(drl0)
            j= j+1
        End If
    Next
Next
For k As Integer = 0 To j-1
    If Filter > ""  Then
        Filter = Filter & " or "
    End If
    filter = filter & "[T246Id] = '" &  drl(k)("T246Id")  &  "'"
Next


使它能够从外部数据源筛选出数据呢?
(这段代码大概的意思是在每年的上一年11月5日到下一年的11月5日之间从这一年段的若干条记录筛选出最晚的记录,就是最接近下一年11月5日的记录)
ps:F4411是日期,T246是表,F4386是用户姓名,T246ID是唯一标识每一行。




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


加好友 发短信
等级:管理员 帖子:47497 积分:251403 威望:0 精华:91 注册:2008/6/17 17:14:00
  发帖心情 Post By:2016/10/23 17:55:00 [只看该作者]

这里用的是SQLFind:

Dim dr1 As DataRow = DataTables("T246").SQLFind("[F4411] Is Not Null", "F4411", 0)

但是这里用的是Find:

drl0 = DataTables("T246").Find("[F4411] >= #" & d1 & "# And [F4411] <= #" & d2 & "# And [F4386] ='" & val & "'","F4411 Desc",0)

这是为什么?

 

筛选后台数据:

Dim Filter AS string = "[T246Id]  in ("

For each dr as datarow in drl
    filter = filter & "'" & dr("T246Id") & "',"
next
Filter = Filtrer.Trim(",") & ")"
DataTables("T246").LoadFilter = Filter
DataTables("T246").Load
 
 

IN运算符

IN运算符是用来判断一个表达式的值是否属于一个指定列表中的值。

例如同样是加载产品PD01和PD02的订单,用IN运算符可以简化为:

SELECT * FR OM {订单} WHERE 产品 IN ('PD01','PD02')

可以用NOT关键词来进行反向的操作,例如加载除产品PD01和PD02之外的订单:

SELECT * FR OM {订单} WHERE 产品 NOT IN ('PD01','PD02')

显然,指定的值越多,IN运算符的优势越明显。

 

 

注意如果是数值列,就不需要用单引号,例如:

 

编号 IN (1,2,3)


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


加好友 发短信
等级:幼狐 帖子:141 积分:904 威望:0 精华:0 注册:2016/8/4 10:50:00
  发帖心情 Post By:2016/10/24 14:01:00 [只看该作者]

不好意思,是我疏忽了,那只要把find改为SQLFind,GetValues改为SQLGetValues就可以用这段代码从后台处理全部数据了?

 回到顶部