teratail header banner
teratail header banner
質問するログイン新規登録

回答編集履歴

1

コード例の追記

2019/08/28 12:06

投稿

hatena19
hatena19

スコア34367

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
+ ```