うまく説明できないのですが、
テーブル1 テーブル2
No|名前 ID|午前担当|午後担当
―――― ――――――――――
01|Aさん 01| 1| 2
02|Bさん 02| 3| 4
03|Cさん 03| 5| 1
04|Dさん 04| 2| 3
05|Eさん 05| 4| 5
上の2つのテーブルを結合させて、
結合後テーブル
No|午前担当|午後担当
――――――――――
01| Aさん| Bさん
02| Cさん| Dさん
03| Eさん| Aさん
04| Bさん| Cさん
05| Dさん| Eさん
上のように表示させたいのですが、
どのように結合したらよいのでしょうか?
どうぞ、ご教授よろしくお願いしますm(_ _)m
No.2ベストアンサー
- 回答日時:
>どのように結合したらよいのでしょうか?
テーブル2に対してテーブル1を2つ結合させれば出来ます。
下記ではテーブル1を2回結合させるためテーブル1とテーブル1_1として結合させています。
SELECT テーブル2.ID, (テーブル1.名前) AS 午前担当, (テーブル1_1.名前) AS 午後担当
FROM (テーブル2 LEFT JOIN テーブル1 ON テーブル2.午前担当 = テーブル1.[No]) LEFT JOIN テーブル1 AS テーブル1_1 ON テーブル2.午後担当 = テーブル1_1.[No]
ORDER BY テーブル2.ID;
INNER JOINを使うとテーブル2の午前・午後担当フィールドにNullがあった場合表示されないのでLEFT JOINとしてNullの場合も表示させるよう対応しています。
Nullは絶対ないという場合ならLEFT JOINをINNER JOINとしても大丈夫です。
これで出来ます。
No.1
- 回答日時:
「課題の丸投げ」のような、質問の仕方はやめましょう。
ここの規約違反になり、削除さえる可能性があります
よ?
create table t1
(No smallint,
namae varchar(1));
insert into t1 values(1,'A');
insert into t1 values(2,'B');
insert into t1 values(3,'C');
insert into t1 values(4,'D');
insert into t1 values(5,'E');
create table t2
(ID smallint,
AM smallint,
PM smallint);
insert into t2 values(1,1,2);
insert into t2 values(2,3,4);
insert into t2 values(3,5,1);
insert into t2 values(4,2,3);
insert into t2 values(5,4,5);
select x.ID,x.namae,y.namae
from
(select ID,namae
from t2 left join t1 on AM=No) as x
inner join
(select ID,namae
from t2 left join t1 on PM=No) as y
on x.ID=y.ID;
※left joinのところは、inner joinでもいいのですが、「担当者を置かないこともある」と考えると、left joinがいいと考えました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
誕生日にもらった意外なもの
みなさんがもらった誕生日プレゼントで面白いものがあったらぜひ教えてください!
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
GROUP BYを行った後に結合したい。
Oracle
-
クエリで同一テーブルの複数回参照について
その他(Microsoft Office)
-
[SQL]重複内容を持つデータから1件抽出かつ複数のカラムを表示したい
その他(データベース)
-
-
4
キーが同じを複数行を1行にまとめるには?
Oracle
-
5
【SQL】他テーブルに含まれる値に合致する行を抽出
その他(データベース)
-
6
Access レコードを追加できません。テーブル’○○’の結合キーがレコードセットにありません。
Access(アクセス)
-
7
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
8
2つの列が同じ値の行を取得するSQL
Oracle
-
9
同一テーブルの同一フィールドで複数条件指定
MySQL
-
10
SQLで特定の項目の重複のみを排除した全項目を取得する方法
その他(プログラミング・Web制作)
-
11
FROM の中で CASE を使えるでしょうか
SQL Server
-
12
Access VBAで int型にnullを入れる方法について
Windows Vista・XP
-
13
yes/no型のチェックができない(アクセス2003)
Access(アクセス)
-
14
クエリで出来た表にチェックボックスを追加する
その他(Microsoft Office)
-
15
Accessを開きなおすとテキストボックスの値がエラー#Name?になる
その他(データベース)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
L2SWはARPテーブルを持っている?
-
男性と2人で飲食店に行きテーブ...
-
会社の飲み会の幹事になり、座...
-
飲み会で、座敷orテーブルどち...
-
一致するデータのみ削除したい
-
テーブルデータのエクスポート...
-
お金持ちのテーブル
-
MySQLで複数テーブルを作成する
-
「テーブルに座って……」という...
-
複数のテーブルの項目を同時に...
-
外部キーだけのテーブル(主キ...
-
phpMyAdminの「リレーションを...
-
Access データベースを分割した...
-
テーブルリンク リンク元を知...
-
オーダーの覚え方について
-
取数計算
-
テーブルサイズ制限について
-
ACCESS での LEFT JOIN 時の WH...
-
席の移動が、当たり前ですか?
-
来賓の座る位置がはっきりしま...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
L2SWはARPテーブルを持っている?
-
男性と2人で飲食店に行きテーブ...
-
外部キーだけのテーブル(主キ...
-
お金持ちのテーブル
-
テーブルリンク リンク元を知...
-
飲み会で、座敷orテーブルどち...
-
「テーブルに座って……」という...
-
面接のときテーブルが正面に。...
-
会社の飲み会の幹事になり、座...
-
オーダーの覚え方について
-
テーブル(構造)のコピー
-
論理名とコメント構文(?)について
-
MySQLで複数テーブルを作成する
-
SQL クエリ データ数
-
SQL 外部結合
-
アクセスのリンクテーブル一覧...
-
【エクセル】データテーブルの...
-
【PHP】SQL文のSUM関数で出力し...
-
件数の多い順にselect
-
1対1のリレーション(主キー同...
おすすめ情報