Microsoft Access 掲示板

テーブルの結合の方法を教えて下さい

20 コメント
views
4 フォロー

お世話になっております。


M_ひらがなマスター

ひらがなIDひらがな
1
2
3
4
5

T_ひらがな表示

IDひらがな1ひらがな2
112

以上のようなテーブルがあるとします。


レポートのレコードソースに、2つのテーブルを結合したクエリを使い、
レポートのtxb_ひらがな1に「あ」、txb_ひらがな2に「い」と表示したいのですが、どのような構成のクエリにすればよいでしょうか?

驚天動地!前任者失踪丸
作成: 2024/03/22 (金) 15:06:07
通報 ...
1
驚天動地!前任者失踪丸 2024/03/22 (金) 16:22:06 23e8e@44ebd
SELECT T_ひらがな表示.ID, M_ひらがなマスター.[ひらがな], M_ひらがなマスター_1.[ひらがな]
FROM (M_ひらがなマスター RIGHT JOIN T_ひらがな表示 ON M_ひらがなマスター.[ひらがなID] = T_ひらがな表示.[ひらがなID]) LEFT JOIN M_ひらがなマスター AS M_ひらがなマスター_1 ON T_ひらがな表示.[ひらがなID2] = M_ひらがなマスター_1.[ひらがなID];

テーブルの表示でM_ひらがなマスターを2つ表示することでレポート用のクエリを作ることが出来ました。
でもこれだと、例えばひらがな3、ひらがな4、、、と増えていくと、その分だけM_ひらがなマスターのテーブルの表示を増やさないといけないですよね?
何か根本的に間違えているような気がするのですが、スマートな実現方法や、間違い等を指摘して頂きたいです。

2
hiroton 2024/03/22 (金) 16:57:09 0858e@f966d

質問の具体例に相当する実際のシステムの具体例が思い浮かびませんが、そっくりそのままやりたいことがそれならそういうものですよ

ただし、

例えばひらがな3、ひらがな4、、、と増えていくと、

のような、「フィールドの数が変動するようなデータ」は通常想定しません。データベース設計としてはNGです
設計段階で「最大個数としてn個ある」のような場合は、その仕様によっては連番で管理されるようなフィールド構造を取る場合もあります

同様の内容が増えていくようなデータの場合は、そのデータ分だけレコード(行)が増えるような形にします

T_ひらがな表示

ID管理IDひらがなNoひらがなID
1111
2122
1211
2222
3233

質問中の「T_ひらがな表示」内の「ID」が、ここで提示した「管理ID」に相当します。「管理ID」が同じレコードを一つのグループとみなす形になります

このように生成したデータを、実際の表示の際に「『管理ID』が同じものを一つのレコードとして扱いたい」場合には、クエリでそのように整形します。手法はいくつかありますが、クロス集計クエリを使うのが一般的でしょう

4
名前なし 2024/03/22 (金) 17:21:48 23e8e@44ebd >> 2

質問は実際のDBを簡略化したものです。
FXのトレード日記をAccessで作成しておりまして、


M_取引根拠

ID根拠
1割安感
2割高感
3プライスアクション
4水平ライン
5トレンドライン

このマスターテーブルを値集合ソースにした3つのコンボボックス(連結列:1、名前:cmb_取引根拠1、cmb_取引根拠2、cmb_取引根拠3)の値をT_トレード日記(例でいうT_ひらがな表示)の取引根拠1、取引根拠2、取引根拠3フィールドに格納します。

このT_トレード日記とM_取引根拠を結合したクエリをレコードソースにして、レポート上で、「割安感」「割高感」といった風に表示したいという感じです。

実現の方法は、自己解決の方法で問題ないということでしょうか?

5
hiroton 2024/03/22 (金) 17:43:42 0858e@f966d >> 2

どの程度を求めるか?ですが、「あまりよくはない」「そうはしないほうが無難」ですかね

困る状況(データベース的におかしい使い方)として、「根拠に〇〇が含まれているトレードを拾い出したい」みたいな要求に応えにくくなります

正規化されていれば、「根拠」フィールドだけを対象にフィルタを掛ければいいですが、横並びで1,2,3としてしまうと、その3つのフィールド全てに対して条件(それぞれのパターンで矛盾しないような)を設定する必要が出てきます。このような運用はデータベース的にNGです

なので、「仕事のシステム」ならそうはしません。「個人使用」ならまぁACCESSでちょっと作っただけだしこんなんでもいいかとしてもいいとは思います(何かやろうとすると間違いなく苦労することになりますが)

12
hiroton 2024/03/25 (月) 15:18:07 ef9cd@f966d >> 2

いまさら気づいたけど>> 2のテーブル例ミスってます
IDの列は単に連番のつもりでした「T_ひらがな表示」の主キー想定です

3

テーブル設計が正規化されていないのでそうなるのは仕方ないですね。

T_ひらがな表示テーブルを正規化するすると、下記のようになります。
これなら、クロス集計クエリで可能です。

T_ひらがな表示

IDOrdひらがなID
111
123
134
142
6
驚天動地!前任者失踪丸 2024/03/25 (月) 11:48:31 23e8e@44ebd

hirotonさん、Hatenaさん、回答ありがとうございます。

Accessの勉強を兼ねて作成していますので、入力したデータは集計・分析に活用したいと考えております。
例えば
・トータル勝率
・買い取引時の勝率
・勝率の高い取引根拠
等です。

入力情報を格納するテーブルの構成を変えて正規化?をするにはどうすればよいでしょうか?
現在の取引履歴を保存するテーブルの校正は画像2・3枚目の通りで、4枚目のようなマスターテーブル(M_●●)があります。

7
驚天動地!前任者失踪丸 2024/03/25 (月) 11:49:27 23e8e@44ebd >> 6

画像1
画像2
画像3
画像4

8
初心者 2024/03/25 (月) 12:36:08 935bc@0e907 >> 7

 正規化云々以前に、もし主キーの設定漏れがある場合、きちんと設定ないと話が始まりませんよ。リレーションシップの設定画面をスクリーンショットを添えて、新しい質問を作りませんか?

9
驚天動地!前任者失踪丸 2024/03/25 (月) 13:21:59 23e8e@44ebd >> 7

あ、T_取引履歴はIDが主キーです。
つけ忘れておりました。

リレーション?は今のところ何も設定していません。

10
初心者 2024/03/25 (月) 13:39:47 935bc@0e907 >> 7

 マスタテーブルを作った理由は?マスタデータを参照してトレード履歴を登録する、そのためにリレーションシップを設定する、という事じゃないの。
 主キーや正規化云々以前に、リレーションシップを設定する必要性が無いのであれば、MsAccessの話が始まらないでしょう。

11

Accessの勉強を兼ねて作成していますので、入力したデータは集計・分析に活用したいと考えております。
例えば
・トータル勝率
・買い取引時の勝率
・勝率の高い取引根拠
等です。

この3つのうち前の2つは現状のままでもいいですが、
勝率の高い取引根拠 を出したいなら、
すでに私やhirotonさんから提案されいてる形(正規形)にした方がいいでしょう。

正規化のやり方は、検索すれば解説ページが多数見つかるのでその中で、分かりやすそうなページを参考にやればいいでしょう。

例えばエントリ根拠に関していえば、
T_トレード履歴 から、エントリ根拠1~5 フィールドを削除して、
T_トレード履歴_エントリ根拠 テーブル作成して
下記のようなフィールド構成にします。

トレード履歴ID   (T_トレード履歴の外部キー)
根拠ID (M_根拠_エントリーのの外部キー)

トレード履歴ID と 根拠ID で複数フィールド主キーに設定。

フォームは、
F_トレード履歴 に T_トレード履歴_エントリ根拠 から作成した帳票フォームをサブフォームとして埋め込めばいいでしょう。

13
驚天動地!前任者失踪丸 2024/03/27 (水) 09:50:38 23e8e@44ebd >> 11

ありがとうございます。Hatenaさん、Hirotonさんに提案されている正規化をやってみたいと思います。

心理状態(エントリー時)、心理状態(クローズ時)も同じマスターテーブル(M_心理状態)から値を拾うのですが、エントリー根拠のように別テーブルにする必要はありますか?

15

心理状態(エントリー時)、心理状態(クローズ時)も同じマスターテーブル(M_心理状態)から値を拾うのですが、エントリー根拠のように別テーブルにする必要はありますか?

データが同じなら、別テーブルにする必要はないです。
リレーションシップを設定するときに、マスターテーブル(M_心理状態)を2つ追加してそれぞれと結合されせればいいでしょう。

14
驚天動地!前任者失踪丸 2024/03/27 (水) 10:28:06 修正 23e8e@44ebd

画像1

T_トレード履歴_エントリー根拠・T_トレード履歴_クローズ根拠のテーブル作成、リレーションシップの設定をしてみましたが、こんな感じでよいのでしょうか?
フォームの入力確定時に保存用テーブル(T_トレード履歴・T_トレード履歴_エントリー―根拠・T_トレード履歴_クローズ根拠)にレコードの書込みを行いたいので、tmpとしています。

M_●●はマスターテーブルです。

画像修正しました。

16
hatena 2024/03/27 (水) 13:55:45 修正

画像を見た限りでは特に問題はなさそうです。

17
驚天動地!前任者失踪丸 2024/03/27 (水) 16:15:05 23e8e@44ebd >> 16

ありがとうございます、作成を進めてみます!
Hatenaさん、Hirotonさん、いつも的確なアドバイス・回答をありがとうございます。

18
驚天動地!前任者失踪丸 2024/03/29 (金) 15:35:29 23e8e@44ebd

お世話になります。
リレーションシップを設定したところ、マスターテーブルの下に+が表示されるようになり、クリックすると別のテーブルのレコードがでてくるのですが、これは問題ないでしょうか?

19

サブデータシートですね。
リレーションシップを設定すると自動で設定されます。
詳細は下記を参照。

サブデータシートはテーブルプロパティで手動設定できる | Access 2019 | 初心者のためのOffice講座

表示させたくなければ、テーブルプロパティで非表示に設定できます。これも上記のリンク先で説明されてます。

20
驚天動地!前任者失踪丸 2024/03/30 (土) 08:25:03 23e8e@44ebd >> 19

なるほど、このような機能があるのですね。

サブデータシートをうっかりさわってレコードを変更してしまわないように非表示にしておきます。