初めてaccessを使います。おそらく本来の使い方(ビジネスなど)と違うため、作り方を検索したり、本屋で本を買おうと思っても知りたいことが書いてないです。(初心者のため、何が知りたいのかもわかっていないかもしれません)
今、作成しているのですが、リストについての操作方法がよくわかりません。
テーブルは二つあります。
両方のテーブルに
番号、単語、訳
の3つのフィールドを作成しました。
作成したいフォームは
(1)リストボックス(1)で使いたいテーブルを選択
(2)(1)で選んだテーブルのデータがリストボックス(2)に表示
(3)(2)で表示された単語を目的の単語をみつけてクリックしてリストボックス(3)に表示
このとき選択した単語番号+30番までなどをリストボックス(3)に表示したいです。
(4)選択した単語+何番までを表示するかを指定したいです。
指定方法としてオプションコントロールでオプションボタンを作成して、10個や20個や50個などをリストボックス(3)に表示できるようにしたいです。
最終的にはテーブルを増やして様々な単語テストが行えるようにしたいです。
実現したいこととして(例:ある単語帳51番から100番までテストしたい)
・単語帳を選択→番号と単語と訳のリストが出てくる→50個の単語が表示されるようにオプションボタンで50を選択→51番の単語を選択→51番から100番までの単語がリストに表示される→印刷ボタンを押すと表示されたリストの単語がレポートに出力され、印刷される
上記を実現したいと考えています。
よろしくお願いします。
また、参考になる本やHPなどの紹介もあわせてよろしくお願いします。
No.1ベストアンサー
- 回答日時:
単語帳: テーブル
[単語帳]__整数
[番号]____整数
[単語]____テキスト
[訳]______テキスト
インデックス:単語帳
primaryKey_単語帳__昇順
___________番号____昇順
このようなテーブル[単語帳]を用意して以下のデータを登録。
単語帳: テーブル
[単語帳]_[番号]_[単語____]_[訳]
単語帳1______1___book_______本
単語帳1______2___pen________筆
単語帳1______3___chair______椅子
単語帳2______1___love_______愛
単語帳2______2___sadness____悲哀
先ずは、[クエリ1]を作成して列[単語帳]に登録されている単語帳の種類を抽出表示。
クエリ1: クエリ
[単語帳]
単語帳1
単語帳2
次に、[クエリ2]を作成して'単語帳1'に属する単語を抽出表示。
クエリ2: クエリ
[番号]_[単語]_[訳]
____1___book___本
____2___pen____筆
____3___chair__椅子
つまり、単語帳は幾らでも増やせることが判ります。
また、それぞれの'単語帳'に属する単語も容易に抽出表示できることが判ります。
で、先ずは、かかるテーブル設計で'単語帳'をフォームで如何に登録していくかがテーマ。
その場合、列[番号]は削除や追加で発生させたりリナンバーさせたりがチトややこしいですね。
クエリ3: クエリ
[カウンタ]_[単語]_[訳]
________1___book___本
________2___chair__椅子
________3___pen____筆
列[番号]の管理が面倒と思うのであれば、このように抽出・参照を綴り昇順にしてカウンタを付与。
そういう手もあります。
リストボックスへの表示の前にテーブルでのデータの管理要領、参照要領の思案が先だと思いますよ。
なお、参考書、入門者の類は読んだことがありません。
Access のヘルプ文が基本中の基本参考書だと思いますよ。
先ずは、ヘルプ文を熟読されたがいいです。
この回答への補足
大変ありがとうございます!
テーブルとクエリについて上記のように作成し、クエリを実行したところ望む結果を得ることができました。
またフォームについてリストを選択することで新たなリストに代入し、表示させることも実現しました。
後は最終的に表示させるリストの単語数なのですが、
オプションコントロールで何個かを指定したいです。
現在は、リストボックス(2)から(3)へ指定したレコードから30個指定するのに
クエリの抽出条件で
Between [Forms]![単語テスト]![単語リスト] And [Forms]![単語テスト]![単語リスト]+29
として30個表示させることはできました。これをオプションボタンで可変にするにはどうしたらよいでしょうか?
単語テスト→フォームの名前
単語リスト→質問文のリストボックス(2)のこと
です。
No.4
- 回答日時:
#3です。
乗りかかった船でやってみました。単語帳1フォームのヘッダーに、コンボボックスと、印刷プレビューボタンを設けて、単語帳1というレポートを作成しておき、
1.選択したレコードから、コンボボックスで選択した個数分フィルター
Private Sub コマンド6_Click()
Me.Filter = "ID >= " & Me.ID & " AND ID <= " & Str(Me.ID + コンボ9.Value - 1)
Me.FilterOn = True
End Sub
2.1でフィルターをかけた範囲をレポートプレビュー
Private Sub コマンド11_Click()
If IsNull(コンボ9.Value) Then Exit Sub
DoCmd.OpenReport "単語帳1", acViewPreview, , "ID >= " & Me.ID & " AND ID <= " & Str(Me.ID + コンボ9.Value - 1)
End Sub
単語帳の数だけ、フォームとレポートを作らないといけないのが面倒ですね。
この回答への補足
ありがとうございます!
大変ありがたく参考にさせていただきます。
現在は#1様の回答を参考に作成を始め、リストの表示までこぎつけることができました。
今後作っていくうえで、参考にさせていただきます。
今は#1様の補足に書き込んだことについて困っています。もしアドバイスなどあればよろしくお願いします!!
No.3
- 回答日時:
Huskey2007さんの回答は実践的で参考になりますね。
素人なりに別の切り口で考えてみました。
Excel発想を離れ、Accessの機能を活用します。
1.単語帳リスト(ID,単語帳名)、単語帳1(ID、単語、訳)、単語帳2というテーブルを作成します。単語帳リストには、単語帳1、単語帳2というデータを入れます。簡単にするため、各IDは数値型で考えています。
2.各テーブルを元に、フォーム/新規作成で自動で作成できる帳票フォームを作成しておきます。フォームの名前はテーブルと同じ名前にして保存しておきます。(混乱の元なので本当はお勧めしませんが、説明を簡単にするために採用しています)
3.単語帳リストのフォームの詳細フィールドにコマンドボタンを配置して、次のコードを登録します。
Private Sub コマンド4_Click()
DoCmd.OpenForm Me!単語帳名
End Sub
これで、単語帳リストフォームから、単語帳の名前の所のボタンをクリックすると、対応する単語帳の帳票フォームが開く様になります。
4.次に単語帳1のフォームを改造します。詳細フィールドに、コマンドボタンを配置して、次のコードを登録します。
Private Sub コマンド6_Click()
Me.Filter = "ID >= " & Me.ID & " AND ID <= " & Str(Me.ID + 10)
Me.FilterOn = True
End Sub
これで、選択したレコードを始点に、+10個目までのレコードがフィルターがかけられて表示されます。単語帳2についても同様のフォームを作成します。
この10を帳票フォーム上のヘッダーに設けたコントロールから選択できる様にすれば、お望みの事に近い機能が実現できると思います。
(注)コマンドボタンの4,6は自動で付けられた成り行きの番号です。念のため。
No.2
- 回答日時:
>本来の使い方(ビジネスなど)と違うため
一見したところ、ビジネスの課題ではないが、特殊とは思いません。
初心者にしては、コントロール(フォーム上の部品、リストボックスやオプションボタンなど)を使いすぎているとは思いましたが。
ーー
だからアクセス独自というよりも、コントロールの使い方の解説書を読むべきだとおもう。
>知りたいことが書いてないです
うそです。この程度のことは、書いてあるが、自分で自分の課題に当てはめられないだけです。
ー
何番から何個選択は、テキストボックスなどの方が良いのではと思う。
個別飛び飛び選択ならリストボックスのマルチセレクト機能を使うとか。
2つー10個以内ぐらいの中から1つを選ぶなら、コマンドボタンを2つ以上並べて、クリックしたほうで、選別する手もある。
その後フォームの切り替えが必要で、この件も勉強が必要。
ーー
気持ちを伝えるのは質問のような文章になるが、質問ー回答という面からすると、余分な文章が多く、質問の内容を的を絞って、箇条書きにでもして質問すべきです。
ーー
あるコントロールで選択ナリしたことを、別のコントロールやクエリに渡すにはどうするかが、勉強する課題だと思う。
Requeryの問題とか。
おっしゃられる通りで、実力が極度に不足しています。
本来ならばもっと時間をかけてやるべきなのでしょう。
しかし、すぐにでも使いたいということと、仲間内でしか使わないことから、見栄えや、高機能である必要はありません。
当初「これくらいのことならすぐできるものなはず」と思い、
できなかったため質問させていただきました。
簡単と思っていたことがいかに難しいのか、今感じています。
自分の実力をまったく把握できていませんでした。
今後時間が作って少しづつ学んでいきたいと思います。
アドバイスありがとうございます!!
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Access(アクセス) AccessVBAで降順にするテーブル作成クエリを使用して作成したテーブルを削除し同一のテーブル作成 1 2023/01/06 11:17
- Excel(エクセル) Excelヘルプの原文を表示する最速の方法(手順)には? 1 2023/08/11 11:30
- Excel(エクセル) 【Excel】指定のセル内容を基に別シートのセルを検索して選択する【VBA】 1 2022/06/16 16:16
- Excel(エクセル) エクセルについて教えてください。 2 2023/06/14 11:11
- Excel(エクセル) エクセルでキーリストからデータを取り出して1枚1枚印刷するには? 11 2022/06/27 09:52
- SQL Server DBのテーブルの設計ができず困っています。 2 2023/06/29 16:43
- Access(アクセス) Access 登録ボタンからサブフォームの更新 1 2022/07/22 10:23
- Excel(エクセル) VLOOKUP が機能しない、その原因は何 ? 8 2022/10/19 12:06
- 英語 ソシュール言語観による品詞、単語、辞書理解の誤り 4 2022/11/24 12:27
- Excel(エクセル) マクロでボタンにつける名前がどこに設定されているかわからないケースがありました。 1 2023/06/19 19:37
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
字面がカッコいい英単語
-
慶應法の難語類推問題対策とし...
-
英単語
-
日東駒専の英語の一般で、8割以...
-
英単語や英熟語のcsvデータが欲...
-
知らない単語の割合
-
単語帳などで覚えたいのに赤字...
-
単語帳、データベース4500につ...
-
英検準1級の単語だけで大学受験...
-
関西外国語大学の公募推薦を考...
-
英語についての質問です。 Data...
-
これらの英単語はいつ習うもの...
-
高3理系です。 大学受験の英単...
-
単語帳は毎日一周して覚えます...
-
【英文解釈】(一見)簡単な英...
-
ターゲット1900完璧にした場合...
-
単語を覚えるときに、赤い文字...
-
ターゲット1400を終えたのでシ...
-
英単語ターゲット1400で国公立...
-
会津大学入試についてです。 英...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
字面がカッコいい英単語
-
関西外大の受験を考えている高3...
-
古文単語315について質問です。...
-
単語を覚えるときに、赤い文字...
-
知らない単語の割合
-
高校英語の誤りを正す問題です...
-
皆さんの模試の解き直しの仕方...
-
関西外国語大学を目指していま...
-
英単語ターゲット1400で国公立...
-
英単語や英熟語のcsvデータが欲...
-
関西大学合格を目指しています ...
-
ビリギャルはいったい1日に何個...
-
単語帳などで覚えたいのに赤字...
-
関西外国語大学の公募推薦を考...
-
産近甲龍レベルなら ターゲット...
-
関大英語はターゲット1900すべ...
-
理科大 工学部は シス単 三章+...
-
英単語のデータが欲しい。
-
英単語の暗記。 英単語は一字一...
-
英単語
おすすめ情報