回答編集履歴
1
コード例の追記
answer
CHANGED
@@ -6,4 +6,37 @@
|
|
6
6
|
デザインビューでフォームヘッダー部分の高さを広げて、そこに検索値入力用のテキストボックスを配置します。
|
7
7
|
|
8
8
|
あとは、提示のコードの感じで動作すると思います。
|
9
|
-
もう少し効率的な記述はありますが。
|
9
|
+
もう少し効率的な記述はありますが。
|
10
|
+
|
11
|
+
コード例
|
12
|
+
---
|
13
|
+
|
14
|
+
**仕様**
|
15
|
+
各テキストボックスの名前をtxt年齢、txt住まい、txt名前、txt性別 とします。
|
16
|
+
「年齢」フィールドは数値型、他はテキスト型とします。
|
17
|
+
年齢と性別は完全一致、住まいと名前は部分一致とします。
|
18
|
+
|
19
|
+
|
20
|
+
```vba
|
21
|
+
Private Sub 検索ボタン_Click()
|
22
|
+
Dim WhereString As String
|
23
|
+
If Me.txt年齢 >= 0 Then
|
24
|
+
WhereString = WhereString & " AND 年齢 = " & Me.txt年齢
|
25
|
+
End If
|
26
|
+
|
27
|
+
If Me.txt住まい <> "" Then
|
28
|
+
WhereString = WhereString & " AND 住まい like '*" & Me.txt住まい & "*'"
|
29
|
+
End If
|
30
|
+
|
31
|
+
If Me.txt名前 <> "" Then
|
32
|
+
WhereString = WhereString & " AND 名前 like '*" & Me.txt名前 & "*'"
|
33
|
+
End If
|
34
|
+
|
35
|
+
If Me.txt接別 <> "" Then
|
36
|
+
WhereString = WhereString & " AND 性別 = '" & Me.性別 & "'"
|
37
|
+
End If
|
38
|
+
|
39
|
+
Me.Filter = Mid(WhereString, 6)
|
40
|
+
Me.FilterOn = (WhereString <> "")
|
41
|
+
End Sub
|
42
|
+
```
|