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

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

ただいまの
回答率

89.12%

MySQLで単一レコードの複数カラムから別テーブルの一致レコードをリクエストする方法

解決済

回答 1

投稿

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

sika

score 45

WEBページにてオブジェクト同士をドラッグ操作で並び替えをして
その隣接したオブジェクト同士の関連URL一覧を比較するといった自作システムを作成しています。
その比較の前段階として選択したひとつのオブジェクトのURL一覧を格納するための工程にて質問させていただきます。

処理の流れとしてはAjaxの非同期通信でオブジェクトを選択したIDをキーとして
PHPで『マスターテーブル』にコマンドリクエストして

【マスターテーブル】
┌ ─ ─ ─ ┬ ─ ─ ─ ┬ ─ ─ ─ ─ ┬ ─ ─ ─ ─ ┬ ─ ─ ─ ─ ┬ ─ ─ ─ ─ ┐
│  ID       │ NAME   │   URL_01   │   URL_02  │  URL_03   │  URL_04   │ 
├ ─ ─ ─ ┼ ─ ─ ─ ┼ ─ ─ ─ ─ ┼ ─ ─ ─ ─ ┼ ─ ─ ─ ─ ┼ ─ ─ ─ ─ ┤
│  1       │ NAME   │   URL_id① │  URL_id② │  URL_id③ │  URL_id④  │ 




│  100     │  NAME  │   URL_id① │  URL_id② │  URL_id③ │  URL_id④  │ 
└ ─ ─ ─ ┴ ─ ─ ─ ┴ ─ ─ ─ ─ ┴ ─ ─ ─ ─ ┴ ─ ─ ─ ─ ┴ ─ ─ ─ ─ ┘

その結果レコードから、さらにその複数カラム
「URL_01」「URL_02」「URL_03」「URL_04」(今後増える可能性あり)に入力された"URL_ID"を
それぞれ『外部サイトテーブル』から抽出させて

【外部サイトテーブル】
┌ ─ ─ ─ ┬ ─ ─ ─ ─ ─ ─ ┬ ─ ─ ─ ─ ─ ─ ┐
│URL_id   │    SITE_NAME   │       URL         │ 
├ ─ ─ ─ ┼ ─ ─ ─ ─ ─ ─ ┼ ─ ─ ─ ─ ─ ─ ┤
│  1       │  サイト名   │  http//~        │ 




│  200    │  サイト名   │  http//~        │ 
└ ─ ─ ─ ┴ ─ ─ ─ ─ ─ ─ ┴ ─ ─ ─ ─ ─ ─ ┘

『マスターテーブル』のURL_ID項目の数だけ配列として出力したいのです

【出力させたい配列結果】

// マスターテーブル"ID"の33をリクエストした場合
$arrayURL = array(
    array(
        'ID'        => 165,
        'SITE_NAME' => サイト名,
        'URL'     => 'http://~',
    ),
    array(
        'ID'        => 87,
        'SITE_NAME' => サイト名,
        'URL'     => 'http://~',
    ),

        ・
    ・
    ・
);

結果的には上記の様な配列として格納できるテーブル出力できるSQLコマンドがわかりません。

また、現在構想している自作ページのシステムの根本的な仕様上、
このAjaxによるリクエスト操作が短時間に高頻度で行われるため、その都度

①Ajaxリクエスト
②PHPでDBコマンド
③DBデータを配列格納
④Ajaxで配列受け取り
⑤JSで配列分解・DOM操作

という一例流れが、主にサーバーサイド側(サーバー負担やメンテナンス面)の不安要素やデメリットが無いか?
選択オブジェクトのIDもとに参照するのが結果的に『外部サイトテーブル』のレコードならば
現時点では『外部サイトテーブル』のデータレコードが4桁5桁と頻繁には増えない予定ですので
その程度のボリュームのデータならば事前に1度だけページアクセス時に参照オブジェクトのひとつとして読み込んでしまい、細かい参照処理はJSだけで行ってしまった方が良いのか?

質問の要点としては
①.上記内容を一回でリクエストできるSQL構文
②.本件の概要のシステム設計としては前者と後者(または別設計)ではどちらが向いているか?

どちらかでも構いませんので、ご教授宜しくお願い致します。

  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

checkベストアンサー

0

 ①.上記内容を一回でリクエストできるSQL構文

SELECT o.*
FROM master AS m
LEFT OUTER JOIN outer_site AS o
  ON o.URL_id IN (m.URL_01, m.URL_02, m.URL_03, m.URL_04)
WHERE m.ID = 33;

実行結果 : http://sqlfiddle.com/#!9/7878d/1

 ②.本件の概要のシステム設計としては前者と後者(または別設計)ではどちらが向いているか?

私の所感としては、
【外部サイトテーブル】の更新頻度が低い(多少、古いデータを見せてしまってもかまわない)のであれば、
「一度 Ajaxリクエストしたデータだけをオブジェクトとして保持しておき、次回以降はそれを参照する」
くらいがちょうどよいのではないかと思います。

ただし、

短時間に高頻度

のリクエストというものが具体的にどの程度なのか、
さらにはサーバやクライアントのスペック、ネットワークの環境なども不明なので、
確かなことは言えません。

『前者』の設計でも心配するほどの負荷にならない可能性もありえますし、
むしろ下手にチューニングすることで

  • 想定外の場所がボトルネックになったり、
  • バグを生じやすくなったり、
  • アプリケーションを変更しにくくなったり

する可能性も考えられるからです。

早めに実装して性能試験を行なってみるしかないのではないでしょうか。

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2017/06/18 02:40

    検証ページまでありがとうございます。
    IN演算子の概念を理解する事ができました。

    私自身、サーバーサイドの知識が乏しいため
    実装後に想定外のバグで対応が遅れる事も避けたいので

    「一度 Ajaxリクエストしたデータだけをオブジェクトとして保持しておき、次回以降はそれを参照する」案で仕様変更を試みてみます。
    ありがとうございました。

    キャンセル

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

  • ただいまの回答率 89.12%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる
  • トップ
  • PHPに関する質問
  • MySQLで単一レコードの複数カラムから別テーブルの一致レコードをリクエストする方法