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で質問しましょう!
似たような質問が見つかりました
- Access(アクセス) チェックボックスにチェックが入った後の挙動 1 2022/08/21 12:39
- Visual Basic(VBA) 【VBA】写真の貼り付けコードがうまく機能しません。 5 2022/09/01 18:43
- Access(アクセス) docmd.gotorecordを起動するには 5 2022/06/17 15:20
- Visual Basic(VBA) Excel VBAの解読について質問があります。 概要は、マクロでチェックボックスにチェックすると日 1 2023/02/10 07:50
- Visual Basic(VBA) ユーザーフォーム「frm_基本❶」を立ち上げると新規で入力する行数を右下のNoとして表示しています。 1 2023/03/16 19:02
- Access(アクセス) DoCmd.SearchForRecord が動かない時の解決方法 3 2022/07/22 15:31
- Visual Basic(VBA) VBA 参照先で選んだファイルをコピーし、出力先に別名で保存したい 8 2022/05/13 20:37
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
- Visual Basic(VBA) VBAが止まります。 3 2022/08/31 14:09
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
YES/NO型の値
Excel(エクセル)
-
レコードを保存するコード アクセスvba
その他(Microsoft Office)
-
VBとアクセスでSQL文に変数を使いたいのですが
Visual Basic(VBA)
-
-
4
アクセスでフォームビューがみれません?
Access(アクセス)
-
5
Accessで、フォームからフォームへ値を引き継ぐやり方
Access(アクセス)
-
6
サブフォームの新規レコードに移動したい アクセス
Access(アクセス)
-
7
Access でレコードセレクタが押されたときのイベントは?
その他(プログラミング・Web制作)
-
8
ACCESSでテーブルにあるチェックボックスを一括でYesにする方法を教えてください
Access(アクセス)
-
9
Acccessで2つのテーブルから1つのフォームをつくりたい
Access(アクセス)
-
10
Accessのサブフォームから値を参照する方法について
その他(データベース)
-
11
ACCESSテーブルを RecordSet以外で1レコードづつ読む方法
Visual Basic(VBA)
-
12
ACCESS 「パラメータの入力」を消したい!!
Access(アクセス)
-
13
ACCESSでクエリを作成したら「式が複雑すぎます。」の表記が…
その他(データベース)
-
14
アクセスで数値型のフィールドにNullをいれたい
その他(データベース)
-
15
【Access】クエリで抽出したデータをCSV形式でエクスポートできますか?
Access(アクセス)
-
16
ACCESS 表形式フォームで1レコードずつ計算したい
Visual Basic(VBA)
-
17
ACCESSのフォームからデータの追加ができない
その他(データベース)
-
18
ACCESSのサブフォームからメインフォームへの移動
Access(アクセス)
-
19
サブフォームが見えなくなる。
Access(アクセス)
-
20
クエリで出来た表にチェックボックスを追加する
その他(Microsoft Office)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ファイル書込みで一行もしくは...
-
JSPのNULLレコード表示について...
-
ADO VBA 実行時エラー3021
-
ヘッダレコードとトレーラレコ...
-
レコードが存在しなかった場合
-
Access を×ボタンで閉じ...
-
差し込み印刷のレコード数について
-
DataGridViewの、選択されてい...
-
DataGridViewの内容をDBに反映...
-
カレントレコードが無い事を判...
-
VB6.0のIsNull関数に相当するもの
-
固有レコード識別子の選択とは
-
【ExcelVBA】Powerクエリーでい...
-
[VBA] ADOの Clone と AddNew
-
[VB6]プログレスバーコントロー...
-
Access でレコードセレクタが押...
-
アクセスでレポートの1印刷内...
-
レコードセット(ADO.Recordset)...
-
ADODCとデータグリッドを連動さ...
-
Accessでレコードの更新を任意...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
レコードが存在しなかった場合
-
ADO VBA 実行時エラー3021
-
ファイル書込みで一行もしくは...
-
アクセスでレポートの1印刷内...
-
カレントレコードが無い事を判...
-
差し込み印刷のレコード数について
-
レコードセット(ADO.Recordset)...
-
ワードの差込印刷で教えて下さ...
-
DataGridViewの内容をDBに反映...
-
Access でレコードセレクタが押...
-
DataGridViewの、選択されてい...
-
JSPのNULLレコード表示について...
-
ACCESSで大量の更新を行うと「...
-
[VBA] ADOの Clone と AddNew
-
Access を×ボタンで閉じ...
-
サブレンジ分割されたNDB(富士...
-
ヘッダレコードとトレーラレコ...
-
データセットのレコード更新が...
-
DataGridViewにてセル以外をク...
-
Line Inputで文字化け(助けて...
おすすめ情報