我有一个主表单和一个表格子表单。我正在应用多个过滤器来过滤我的主窗体但我的子窗体与父和子字段属性链接,所以我只能在一个字段上应用过滤器。
如何在子表单中将相同的过滤器应用到我的主窗体中?
以下是我的代码,以帮助您了解:
Private Sub Filtermainform()
Dim strWhere As String
'Make string
If Nz(Me.Combo56, "") <> "" Then
If IsNumeric(Me.Combo56) Then
strWhere = strWhere & "[" & Me.Combo54 & "] = " & Me.Combo56 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo54 & "] = '" & Me.Combo56 & "' AND "
End If
End If
If Nz(Me.Combo109, "") <> "" Then
If IsNumeric(Me.Combo109) Then
strWhere = strWhere & "[" & Me.Combo107 & "] = " & Me.Combo109 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo107 & "] = '" & Me.Combo109 & "' AND "
End If
End If
If Nz(Me.Combo112, "") <> "" Then
If IsNumeric(Me.Combo112) Then
strWhere = strWhere & "[" & Me.Combo111 & "] = " & Me.Combo112 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo111 & "] = '" & Me.Combo112 & "' AND "
End If
End If
If Nz(Me.Combo114, "") <> "" Then
If IsNumeric(Me.Combo114) Then
strWhere = strWhere & "[" & Me.Combo113 & "] = " & Me.Combo114 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo113 & "] = '" & Me.Combo114 & "' AND "
End If
End If
If Nz(Me.Combo116, "") <> "" Then
If IsNumeric(Me.Combo116) Then
strWhere = strWhere & "[" & Me.Combo115 & "] = " & Me.Combo116 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo115 & "] = '" & Me.Combo116 & "' AND "
End If
End If
If Nz(Me.Combo118, "") <> "" Then
If IsNumeric(Me.Combo118) Then
strWhere = strWhere & "[" & Me.Combo117 & "] = " & Me.Combo118 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo117 & "] = '" & Me.Combo118 & "' AND "
End If
End If
If Nz(Me.Combo120, "") <> "" Then
If IsNumeric(Me.Combo120) Then
strWhere = strWhere & "[" & Me.Combo119 & "] = " & Me.Combo120 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo119 & "] = '" & Me.Combo120 & "' AND "
End If
End If
If Nz(Me.Combo122, "") <> "" Then
If IsNumeric(Me.Combo122) Then
strWhere = strWhere & "[" & Me.Combo121 & "] = " & Me.Combo122 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo121 & "] = '" & Me.Combo122 & "' AND "
End If
End If
If Nz(Me.Combo124, "") <> "" Then
If IsNumeric(Me.Combo124) Then
strWhere = strWhere & "[" & Me.Combo123 & "] = " & Me.Combo124 & " AND "
Else
strWhere = strWhere & "[" & Me.Combo123 & "] = '" & Me.Combo124 & "' AND "
End If
End If
'Apply filter
If strWhere <> "" Then
strWhere = Left(strWhere, Len(strWhere) - 5) 'Remove the extra AND
Me.Filter = strWhere
Me.FilterOn = True
Else
Me.Filter = ""
Me.FilterOn = False
End If
您可以在MasterField和ChildField规范中包含多个字段,例如:
[Id];[FilterField]
[FK];[FilterField]
要删除过滤器,请将第一个字段加倍,因为您无法修改任何一个规范以使另一个字段数量超过另一个(!),因此:
[Id];[Id]
[FK];[FK]