
ACCESSの表形式のフォームにYES/NOフィールドを足して
一覧フォームで任意のチェックボックスを選択して
選択されたデータのみを表示するようにしたいです。
しかしチェックボックスはレコードひとつひとつについてるのですが
認識されるチェックボックスは一番上のレコードのチェックボックスのみです。どうすればレコード別に判定できるのがわからないので
詳しい方ご教授お願いします。自分が書いたのは下記コードです。
Dim chkBln As Boolean
chkBln = False
If チェック50 = True Then
chkBln = True
MsgBox chkBln
End If
'検索結果の表示
DoCmd.OpenForm ("データ修正画面")
'自身のレコードソースに設定
Forms("データ修正画面").RecordSource = "Select * From T_障害票マスタ WHERE チェック = " & chkBln & ""
No.5ベストアンサー
- 回答日時:
No.3です。
> 一覧を全件表示しているフォームは一覧表形式なので、すべてのレコードの
> チェックボックスが"チェック50"になるので判定をどうすればいいのかわかりません。
・・・すみません、前回の回答で説明用の画像をつけるつもりでいたはずが、そのまま
忘れていました(汗)
現在、『チェック50』チェックボックスで、テーブルの『チェック』フィールドの値を表示
させている(=連結コントロール)のでしたら、フッタに設置したコマンドボタンの隣に、
”チェックボックスを新たに追加”してください。
このチェックボックスの名前を『チェック抽出用』とします。
※「チェック50」チェックボックスは表示用に使用しますので、そのまま残しておきます。
上記に基づいて前回の回答を修正すると、以下のようになります:
(重複するコメントは削除しました)
Private 抽出_Click()
Dim chkBln As Boolean, RecSrc As String
'「データ修正画面」フォームの名前を定数として設定
Const FName As String = "データ修正画面"
'レコードのデータを表示している「チェック50」ではなく、
'フッタに設置した「チェック抽出用」を、抽出条件に使用します。
chkBln = チェック抽出用
MsgBox "chkBln = " & chkBln
'If chkBln Then MsgBox "chkBln = " & chkBln
RecSrc = "Select * From T_障害票マスタ Where チェック = " & chkBln
'「データ修正画面」フォームを開く
DoCmd.OpenForm FName
'レコードソースを設定(定数として設定済みなので「"」括りは”無用”)
Forms(FName).RecordSource = RecSrc
End Sub

いつも詳しい説明ありがとうございます。
ご投稿いただいた方法で無事解決しました。
また、今回作成していた障害管理プログラムも思っていたよりも
ずっと良くできました。
VBAは初めてだったので皆さんのお力添えに感謝いたします。
ありがとうございました。
No.4
- 回答日時:
#2です
> ひとつだけチェックボックスを選択して実行すると全件表示されていしまいます。
> 2つ以上だと先に選択したレコードは表示されず2つのレコードから表示されてしまいます。
もしかしたら、そのチェック項目にチェックした後、確定操作していますか。
また、判別が逆ということはありませんか。
1つ目をチェックして確定せずに修正画面を起動したとしても、レコード内はチェックしたもので更新されていないと思います。
2つ以上だと1つ目が表示されなくて、・・・・
これは、判別が逆だから・・・と思います。
チェックを入れたらすぐに確定するには、
If (Me.Dirty = True) Then
DoCmd.RunCommand acCmdSaveRecord
End If
とか、
Me.Dirty = False
で確定後、OpenForm の処理を、判別逆でやってみてください。
(上記2つ目の方法は私自身試したことはありませんが、あるところで他の方が回答し、それで解決したお礼もありました)
詳しい説明ありがとうございます。
問題はDexMachinaさんが投稿してくれた方法で解決できました。
頂いたアドバイスもこれからの参考にさせていただきます。
またなにかありましたらお願いします。
No.3
- 回答日時:
やりたいことは、
『データ修正画面』で一旦全件表示した後、『T_障害票』テーブルの『チェック』
フィールドがオンまたはオフのものに絞り込んで再表示
ということでよろしでしょうか。
(「自身のレコードソースに設定」とされているので、別フォームではないものと判断)
上記の通りだとすると、チェックボックスは、
・詳細領域(レコードの表示領域)に設置(→レコード毎の値の確認・更新用):
『コントロールソース』に『チェック』フィールドを指定したもの(=連結コントロール)
・フォームのヘッダまたはフッタに設置(→絞り込み条件の指定用):
『コントロールソース』が空白のもの(=非連結コントロール)
の2種類が必要ですので、まずはその点をご確認下さい。
※フォームのヘッダ/フッタは、当該フォームをデザインビューを開いた状態で、メニュー
から「表示(V)→フォーム ヘッダ/フッタ(H)」を選択すると表示されます。
なお、ヘッダまたはフッタの一方のみが必要な場合は、不要な側をダブルクリックする
などしてプロパティシートを表示させ、『書式』タブの『高さ』を「0cm」に設定します。
(または、同タブの『可視』を「いいえ」にしても可)
とりあえず、「チェック50」の方が非連結ということなら、提示のコードでも動くかと
思いますが、不要部分などもありましたので、参考までに少し手を入れてみました。
Private 抽出_Click()
Dim chkBln As Boolean, RecSrc As String
'指定された抽出条件を確認(値を変数に設定)
chkBln = チェック50
'メッセージボックスで値を確認
MsgBox "chkBln = " & chkBln
'チェック50がオンの場合にのみメッセージが必要なら以下に差し替え
'If chkBln Then MsgBox "chkBln = " & chkBln
'SQL文の作成
'(Booleanでは値を「"」等で括る必要がないので末尾の「""」は省略しました)
RecSrc = "Select * From T_障害票マスタ Where チェック = " & chkBln
'自身のレコードソースに設定(自身の場合は「Me」で指定できます)
Me.RecordSource = RecSrc
'※「自身への設定=フォームは展開済」なのでOpenFormは不要です。
End Sub
この回答への補足
ご回答ありがとうございます。
すみません説明不足でした。
チェックボックスは詳細部分に配置してコントロールソースをテーブルのチェックフィールド(yes/no型)に設定しています。
フッタ部分にはコマンドボタンがあり、チェックの入ったフィールドのみをデータ修正画面に表示させたいと思っています。
自身のフォームと書いたのは一度データ修正画面を開いてそれからレコードソースを更新していたのでそう書きました。
一覧を全件表示するフォームとデータ修正画面は別のフォームになります。紛らわしくてすみません。
またレコードは常に一定ではないので非連結だと対応できない可能性があります。(増えたときなど)
一覧を全件表示しているフォームは一覧表形式なので、すべてのレコードのチェックボックスが"チェック50"になるので判定をどうすればいいのかわかりません。
こうゆう場合はどうすればいいのでしょうか?
No.2
- 回答日時:
チェックボックスは、非連結のものでしょうか?
であれば、以下参考になるかと
非連結のチェックボックスでレコードを選択する
http://hatenachips.blog34.fc2.com/blog-entry-28. …
テーブルのフィールドとしてチェックボックスと連結されているものがあるのなら
フォーム「データ修正画面」には、チェックが付いたものだけを表示したいのでしょうか。
であれば、OpenForm での WhereCondition に条件を指定します。(4つ目)
DoCmd.OpenForm "データ修正画面", , , "チェック = " & chkBln
(「チェック」名のフィールドがテーブル「T_障害票マスタ」にあるとして)
フォーム「データ修正画面」のレコードソースは、「T_障害票マスタ」だけを指定しておきます。
※ DoCmd.OpenForm は、一般的に ( ) は付けません(上記の様に)
※ フォーム「データ修正画面」起動後に、レコードソースを書き換えているようですが、フォームの「開く時」イベント(Form_Open)前に、設定されているレコードソースでの抽出は完了しているようですので、後からレコードソースを設定するのであれば、フォームの初期状態で指定しておかない方が良いと思います。
設定していなければ、余計なお世話ということで。
WhereCondition で指定したものは条件として加味して抽出されるようです(Form_Open前に)
ご回答ありがとうございます。
教えて頂いたとおりに(連結の場合)やってみたら。
ひとつだけチェックボックスを選択して実行すると
全件表示されていしまいます。
2つ以上だと先に選択したレコードは表示されず2つのレコードから表示されてしまいます。
しかも理由がわかりません。
こうゆう事ってあるんですか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
MS Accessでフォームの「開く時」と「読込み時」のイベントの違い
Access(アクセス)
-
access クエリ yes/no型のクエリの抽出の記述を教えて下さい。
Access(アクセス)
-
アクセスVBAで既に開いているエクセルを閉じたい
Yahoo!ショッピング
-
-
4
Access コンボボックスの値をクリアしたい。
PowerPoint(パワーポイント)
-
5
フォームを開くときに、コンボボックスの値を選択(アクセスVBA)
Visual Basic(VBA)
-
6
yes/no型のチェックができない(アクセス2003)
Access(アクセス)
-
7
クエリで出来た表にチェックボックスを追加する
その他(Microsoft Office)
-
8
Accessでフォームから別フォームのテキストボックスの値を設定する
Visual Basic(VBA)
-
9
YES/NO型の値
Excel(エクセル)
-
10
レコードを保存するコード アクセスvba
その他(Microsoft Office)
-
11
チェックボックスのON OFFでの切替について
Access(アクセス)
-
12
ACCESSでフォームのチェックボックスにチェックを入れて任意の数値を入力したい!!!
Access(アクセス)
-
13
ACCESSでテーブルにあるチェックボックスを一括でYesにする方法を教えてください
Access(アクセス)
-
14
アクセス:Yes/No型→チェックいれたら、○"を表示。"
Access(アクセス)
-
15
ACCESSのクエリー抽出条件にIIFを使用して
Access(アクセス)
-
16
選択したチェックボックスのみチェックを入れたいのですが
その他(データベース)
-
17
AccessクエリでYes/No型データの抽出
Access(アクセス)
-
18
ACCESSで実行時エラー3008
その他(プログラミング・Web制作)
-
19
アクセスでテキストボックスの値が空白だったら
Access(アクセス)
-
20
Access 同じデータをたくさんのレコード(同一列)に一度に入力するには
Access(アクセス)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ADO VBA 実行時エラー3021
-
postgresql DELETE後commit...
-
データセットのレコード更新が...
-
ファイル書込みで一行もしくは...
-
ADODBのRecordset.Deleteのエラ...
-
Excel VBA読み込みで文字化けが
-
大量のテキストデータの集計に...
-
カレントレコードが無い事を判...
-
ヘッダレコードとトレーラレコ...
-
AccessVBAのMoveメソッドにつき...
-
固有レコード識別子の選択とは
-
ワードの差込印刷で教えて下さ...
-
どのようなレコード構成でもfil...
-
COBOLでのランダムアクセス
-
vb.netのdatatableのレコード削...
-
アクセスでレポートの1印刷内...
-
DataGridViewの内容をDBに反映...
-
Oracleでの文字列連結サイズの上限
-
OracleのSQL*PLUSで、デー...
-
GROUP BYを行った後に結合した...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ADO VBA 実行時エラー3021
-
差し込み印刷のレコード数について
-
レコードが存在しなかった場合
-
アクセスでレポートの1印刷内...
-
DataGridViewの、選択されてい...
-
JSPのNULLレコード表示について...
-
ヘッダレコードとトレーラレコ...
-
ACCESSで大量の更新を行うと「...
-
サブレンジ分割されたNDB(富士...
-
カレントレコードが無い事を判...
-
ワードの差込印刷で教えて下さ...
-
固有レコード識別子の選択とは
-
Access でレコードセレクタが押...
-
[VBA] ADOの Clone と AddNew
-
ファイル書込みで一行もしくは...
-
DataGridViewの内容をDBに反映...
-
VB6.0のIsNull関数に相当するもの
-
Access を×ボタンで閉じ...
-
Accessデータシートビューの行...
-
Line Inputで文字化け(助けて...
おすすめ情報