質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.51%

  • Access

    595questions

    Accessはマイクロソフトによるリレーショナルデータベース管理システムです。オブジェクト指向のアプリケーション作成に対応しており、テーブルや編集をはじめ、クエリ生成、入力フォーム作成、レポート作成など一通りの機能を備えています。

アクセス 階層型でのルックアップの仕方

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 729

yuujiMotoki

score 19

ACCESS2013のデータテーブルについて教えてください。
下記のようなリレーションデータベースを作っています。
idは主キーに割り当てています。

メイン-品名-詳細というような階層構造にしています。

種類

id 品名
1 バナナ
2 リンゴ
3 ミカン

サイズ

ID サイズ
1
2
3

状態 

Id 状態
1
2
3

品名

id 種類 サイズ 状態
1 ミカン

ここまではルックアップフィールドを使って
リストをidが見えないように出来ました。

しかしここからが課題

メインテーブルでは、以下のように品名でリレーションを設けて引っ張ってくると、
以下のように品名が数字(主キー)になってしまいます。
またコンボボックスも数字の表になってしまいます。

メイン

id 品名 数量
1 1 1

品名

id 品名 数量 状態
1 3 1 1

希望

希望としては、下記のような表示にしたいのですが

メイン

id 品名 数量
1 ミカン-大-優 1
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • dit.

    2018/04/06 16:36

    後々混乱のもとになるため、「種類ID」「サイズID」など、内容がわかる名前にした方がいいかと思います。

    キャンセル

  • yuujiMotoki

    2018/04/12 06:09

    ありがとうございます。idだけでも重複しますから、そういう点を直しておけば後々分かりやすいのですね

    キャンセル

回答 1

checkベストアンサー

0

利用用途が良く分かりませんが、求めている結果についてだけなら、以下の様にして見て下さい。

メイン-品名のルックアップで、値集合ソースに以下を指定。

SELECT 品名.id, 種類.品名 & "-" & サイズ.サイズ & "-" & 状態.状態 AS 表示品名 
FROM ((種類 INNER JOIN 品名 ON 種類.id=品名.種類
      ) INNER JOIN サイズ ON 品名.サイズ=サイズ.id
      ) INNER JOIN 状態 ON 品名.状態=状態.id
; 

コンボボックスについては、以下のように指定。
[列数]2
[列幅]0;3

列数はコンボボックスに表示する列の数で、例えば列数=2だとコンボボックスには、idと品名が表示される。
その表示について列幅でidの表示幅=0にすることでidが隠れます。
※尚、連結列はidである必要があるので、コンボボックスの列の並びを変えた場合などには注意すること。

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/04/06 16:19

    ありがとうございました。
    無事にテーブル上に表示させることができました。
    しかしながら、これをEXCELに取り込んだのですが、
    品名の部分が、IDの数字になっています。

    実際の目的としては、EXCEL上に表形式で取り込んで表示させたかったのですが
    やはりテーブルの中では、品名が主キーの数字になっているので、
    どうしようもありませんね。

    表示名をフィールドにして、STRINGで格納するような処理をしなくてはなりません。

    また、これはこれで難しいのですが、何とかなりませんでしょうか?

    キャンセル

  • 2018/04/06 16:28

    エクセルへはテーブルではなく、クエリーを作成し、そのクエリーからの出力とすれば可能です。
    色々処理を考えられているなら、テーブルでのルックアップだけではなく、クエリーを介して行うことも検討された方が良いかと。

    キャンセル

  • 2018/04/12 06:08

    クエリーを使いこなすといいのですね。まだクエリー自体の使いこなしができていませんが、このようにフィールドから所望のデータ形式を引き出すという変換機能としても使えるのですね

    キャンセル

  • 2018/04/12 09:05

    テーブル構成の原則として、演算して取得できるものは項目としない、ということがあります。
    逆にいうと、演算して取得するものはクエリーで行うという事ですから、基本データの取得はクエリーを介して行うという風に考えて差支え無いです。

    キャンセル

同じタグがついた質問を見る

  • Access

    595questions

    Accessはマイクロソフトによるリレーショナルデータベース管理システムです。オブジェクト指向のアプリケーション作成に対応しており、テーブルや編集をはじめ、クエリ生成、入力フォーム作成、レポート作成など一通りの機能を備えています。