三流君 ken3のmemo置き場

メモ置き場、保管庫として利用。まとまっていませんがヨロシク

挨拶・自己紹介:
失敗続きのAB型の変わり者 :三流プログラマー Ken3です
フリーのエンジニア・個人事業主です・・と書くと聞こえはイイが(それとなくカッコよく聞こえるが)、 現在は小さな案件の受注請負 と 短期派遣 で 日々つつましく?ほそぼそと暮らしてます。
(※詳細は[三流君 三流プログラマーとは?]を見てください)


広告:


[記事一覧、バックナンバーを見る]

QA110218 イ.Access メインフォーム、サブフォーム、値の取り出し方?

次に(次の壁は)、値の取り出し方、表現方法です。

メインフォーム
[ドラマタイトル]

サブフォーム [SUB出演者]
[出演者]
[役名]
を取り出してみたいと思います。

Private Sub BTEST_Click()

    'MsgBox "メイン " & Me.ドラマタイトル

    'MsgBox "サブ 出演者 役名 " & Me![SUB出演者]![出演者] & "-" & Me![SUB出演者]![役名]

    'MsgBox "メイン レコード数MAX " & Me.Recordset.RecordCount
    
    'MsgBox "サブ レコード数MAX " & Me![SUB出演者].Form.Recordset.RecordCount

    Dim n As Integer  'カウンター
    Dim strWORK As String  'サブのデータをまとめる
    
    'サブフォーム の レコードを移動させたいのでフォーカスサブに当てる
    Me![SUB出演者].SetFocus       'フォーカスのカーソル移動
    DoCmd.GoToRecord , , acFirst  'サブの先頭レコードにする
    
    strWORK = Me.ドラマタイトル & vbCrLf & vbCrLf  'ワークをタイトルでクリア 2行改行
    For n = 1 To Me![SUB出演者].Form.Recordset.RecordCount
        strWORK = strWORK & Me![SUB出演者]![出演者] & "-" & Me![SUB出演者]![役名] & vbCrLf
        DoCmd.GoToRecord , , acNext  '次のレコードへ
    Next
    DoCmd.GoToRecord , , acFirst  '再度頭にサブの先頭レコードにする
    
    '結果を使う テストで画面に表示
    MsgBox strWORK

End Sub

動画で解説

蛇足や寄り道、ムダに迷っていたりしますが、下記動画解説です。
http://www.youtube.com/watch?v=g1-v0ryuO6E

処理のポイント

1. !と. 同じようで違ったり?

エラー MsgBox "サブ 出演者 役名 " & Me.SUB出演者.[出演者]
正常が MsgBox "サブ 出演者 役名 " & Me![SUB出演者]![出演者] & "-" & Me![SUB出演者]![役名]

2. サブフォームの全てのレコードを取り出したいんだけど・・・

2.1 レコードカウント(MAXのレコード数)
me.Recordset.recordcount で メインは取れる。
使いたいサブフォームのレコード数は、
Me![SUB出演者].Form.Recordset.RecordCount
サブフォームのレコード数を取得することができました。

2.2 サブフォームのレコードを動かしたいんだけど・・・

次に、サブフォームのレコードを動かしたいので、

2.2.1 フォーカスの移動
Me![SUB出演者].SetFocus 'フォーカスのカーソル移動
で、フォーカス/操作の対象をサブフォームにセットしてから、

2.2.2 先頭レコードに移動
DoCmd.GoToRecord , , acFirst 'サブの先頭レコードにする
で、サブフォームの先頭にカーソルを移動させ

2.2.3 レコード数分だけ、レコードを移動さながら 値を集める
ワーク変数を1つ作成して、ループで回してみました。

strWORK = Me.ドラマタイトル & vbCrLf & vbCrLf 'ワークをタイトルでクリア 2行改行
For n = 1 To Me![SUB出演者].Form.Recordset.RecordCount
strWORK = strWORK & Me![SUB出演者]![出演者] & "-" & Me![SUB出演者]![役名] & vbCrLf
DoCmd.GoToRecord , , acNext '次のレコードへ
Next
DoCmd.GoToRecord , , acFirst '再度頭にサブの先頭レコードにする

'結果を使う テストで画面に表示
MsgBox strWORK

終わりのあいさつ

※まぁ、そんなことするなら、DAOやADOで処理すると言われそうですが、
こんな感じの三流処理もあるってことで(笑)

サブフォームのデータ処理で何かの参考となれば幸いです。

で、終わりじゃなかった(笑)質問は、Outlookへデータを書く、転記するのかぁ。
続きは少々お待ちを。
※※処理の全体像は http://ken3hitori.g.hatena.ne.jp/bbs/19?from=1 を見てください。




三流君へ メッセージを送る

全ての質問に答えることはできませんが、
ダメもとで、気軽に質問、感想、メッセージを送ってくださいね・・・

感想や質問・要望・苦情など 三流君へメッセージを送る。
下記のフォームからメッセージを送ることができます。


あなたのお名前(ニックネーム):さん
返信は?:

アドレス:に返事をもらいたい
感想や質問↓:


(感想や質問・要望・苦情はHPで記事に載せることがあります。)
例:[XXXXさんへ回答例]←みたいに回答していたり...


Ken3 ホームページ 目次

分類:HPを大きく分けると4つの柱(分類)です。
・[Excel/Access VBA]の解説
・[ASP(Active Server Pages)]の解説。
・[元コンビニ店長時代の話]が弟に巻き込まれ、失敗した脱サラ、畑違い?の仕事で失敗。
・[プログラマーの愚痴]では、あまり見せたくない三流プログラマーの内面かな。
三流君を踏み台にする
主に上記4つの分類でHP作成やメルマガの発行を行ってます。
※更新頻度が落ちていて情報の鮮度が悪いです。

三流解説動画の再生リスト
https://www.youtube.com/user/ken3video/playlists

本当に三流なんです(笑):たまにスゴイですねなんて言われることもありますが、
真実は→ [三流君の真実は...] ←を初めに見てくださるとわかると思います。
(からくりは、成功例↑しか載せてなくて ヒドイ失敗例はお蔵入り迷宮入りが多かったりします)