プロジェクトA 月間勤務状況一覧
氏名 1月 2月 3月 合計
山田 20 10 10 40
川村 10 10 10 30
大沢 20 20 20 60
上記のような一覧をつくりたいのですが、
STAFF表(社員情報)とLABOR表(勤務情報)からSQL一発で
情報を取り出すためのSQL作成に四苦八苦しています。
人別に情報を取り出すには、GROUPを使えばよいというところまではわかるのですが、
月ごとの情報を取得するために副問い合わせを用いる際に、
人別に情報を取得しようとすると
副問い合わせ文内で社員を指定する必要が出てきてしまいます。
すると社員を纏めて表示するためのGROUPを使う意味がそもそもなくなってしまいます。
以上のような点から、SQLを作る事ができないでおります。
どのように記述すれば宜しいでしょうか?アドバイス頂ければ大変助かります。
No.3ベストアンサー
- 回答日時:
試しにSQLを作ってみました。
create table STAFF
(ID smallint,
名前 varchar(10));
create table LABOR
(ID smallint,
社員ID smallint,
年月日 date,
時間数 smallint,
プロジェクトID smallint);
insert into STAFF values(101,'川口');
insert into STAFF values(111,'宮本');
insert into STAFF values(123,'中田英');
insert into LABOR(社員ID,年月日,時間数) values(101,'2006-01-05',8);
insert into LABOR(社員ID,年月日,時間数) values(101,'2006-02-01',10);
insert into LABOR(社員ID,年月日,時間数) values(101,'2006-02-15',5);
insert into LABOR(社員ID,年月日,時間数) values(101,'2006-03-01',8);
insert into LABOR(社員ID,年月日,時間数) values(101,'2006-03-03',10);
insert into LABOR(社員ID,年月日,時間数) values(101,'2006-03-10',12);
insert into LABOR(社員ID,年月日,時間数) values(111,'2006-01-10',5);
insert into LABOR(社員ID,年月日,時間数) values(111,'2006-01-15',10);
insert into LABOR(社員ID,年月日,時間数) values(111,'2006-01-31',5);
insert into LABOR(社員ID,年月日,時間数) values(111,'2006-02-10',8);
insert into LABOR(社員ID,年月日,時間数) values(111,'2006-02-20',8);
insert into LABOR(社員ID,年月日,時間数) values(111,'2006-03-20',10);
insert into LABOR(社員ID,年月日,時間数) values(123,'2006-01-20',8);
insert into LABOR(社員ID,年月日,時間数) values(123,'2006-01-21',8);
insert into LABOR(社員ID,年月日,時間数) values(123,'2006-01-22',8);
insert into LABOR(社員ID,年月日,時間数) values(123,'2006-03-03',5);
insert into LABOR(社員ID,年月日,時間数) values(123,'2006-03-04',5);
insert into LABOR(社員ID,年月日,時間数) values(123,'2006-03-05',5);
select
x.名前,
coalesce(sum(case when date_part('month',年月日)=1 then 時間数 end),0) as 1月,
coalesce(sum(case when date_part('month',年月日)=2 then 時間数 end),0) as 2月,
coalesce(sum(case when date_part('month',年月日)=3 then 時間数 end),0) as 3月,
coalesce(sum(case when date_part('month',年月日) between 1 and 3 then 時間数 end),0) as 合計
from STAFF as x,LABOR as y
where x.ID=y.社員ID
group by x.名前
order by x.名前
;
この回答への補足
名寄せされてしまう理由は分かりませんでしたが、
STAFFの一意識別子(ID)でGROUPすれば、正しく集計されました。
どうもありがとうございました!
chukenkenkou様
ありがとうございました!
まったく知らなかったSQLです。
勉強になります。
早速、こちらを参考につくってみます。
*なお「宮本」が何故か「川口」と名寄せされて、一緒に集計されてしまうのですが…。
英語名に変えてみたら、正しく集計されました。
1月 2月 3月 合計
川口 28 31 40 99
中田英 24 0 15 39
No.2
- 回答日時:
>2)LABOR表(勤務情報)
>ID
>社員ID(FK:STAFF.ID)
>年月日
>時間数
>プロジェクトID(FK:PROJECT.ID)
「月間勤務状況一覧」で集計しているのは、日数のように見えます。
時間数は無視して、勤務日数でだけ集計できればいいのですか?
こういう質問をする場合は、
(1)基の各表の列構成
(2)基の各表に入っているデータ例
(3)得たい検索結果
を示してくれないと、適切な回答ができません。
(3)は、質問で示されています。
(1)は、#1さんへの補足説明で示されました。
(2)は、示せませんか?
この回答への補足
chukenkenkou様、回答有り難うございます&言葉足らずで申し訳ありません。
下記の通り回答させていただきます。
・「月間勤務状況一覧」で集計しているのは、時間数です。勤務時間数は日によって異なるため、月ごとに時間数を集計します。
・表に入っているデータは以下の通りです。
1)STAFF表(社員情報)
ID:100
名前:山田太郎
2)LABOR表(勤務情報)
ID:200
社員ID(FK:STAFF.ID):100
年月日:2006/01/03
時間数:8
プロジェクトID(FK:PROJECT.ID):300
3)PROJECT表(プロジェクト情報)
ID:300
プロジェクト名:ヘルスケア事業
以上、他にご不明な点がありましたらご指摘頂ければ幸いです。
No.1
- 回答日時:
STAFF表(社員情報)とLABOR表(勤務情報)の構成がわかりません...
この回答への補足
ご指摘有り難うございます&言葉足らずで申し訳ありません。
テーブルの構成ですが大まかに言って下記の通りです:
1)STAFF表(社員情報)
ID
名前
2)LABOR表(勤務情報)
ID
社員ID(FK:STAFF.ID)
年月日
時間数
プロジェクトID(FK:PROJECT.ID)
3)PROJECT表(プロジェクト情報)
ID
プロジェクト名
以上の通りです。
もし説明不足等ありましたらご指摘頂ければ幸いです。
宜しくお願い致します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- SQL Server ACCESSで表が作りたく、そのためのSQL文や設定方法を教えてください。 1 2022/08/15 12:28
- MySQL SQLです。下記の問合せを行うクエリを、PhpMyAdminで作成して実行せよ。 「昨年の各月の総降 1 2023/07/01 00:32
- 政治 今にして思えば、アメリカの大統領がトランプではなくて、バイデンで良かったですね? 4 2022/06/11 06:10
- コンサルティング・アドバイザー UL など海外規格をまとめる方法について 3 2023/08/16 10:29
- その他(資産運用・投資) 助けてください 株購入、配当について 正式なグリー株式会社から 身に覚えのない手紙が届きました。 手 8 2023/08/28 12:50
- MySQL 【投稿情報用データベース posts】は必要ないと思います。 1 2022/06/02 21:25
- 不動産鑑定士・土地家屋調査士 合筆された地積測量図の取得(登記情報提供サービス) 1 2022/07/13 00:30
- Wi-Fi・無線LAN PCWi-Fiの設定方法がわからなくて困っています。 4 2022/12/28 18:30
- 消費税 委任・準委任契約とインボイス制度 1 2023/06/11 08:24
- その他(法律) 携帯電話会社に保管されている解約済み個人情報を消去したい 3 2022/08/13 23:23
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
NULL か UNIQUE な列は作成可能?
-
timestampのデータはどのように...
-
フラグをたてるってどういうこ...
-
【SQL】他テーブルに含まれる値...
-
Excel VBAのユーザーフォームで...
-
結合したテーブルをSUMしたい
-
sqlに記述できない文字
-
ExcelのMatch関数のようなもの...
-
selectの単純繰り返し
-
右向き、左向きの速度が最大と...
-
UPDATEで既存のレコードに文字...
-
PRIMARY KEYのコピー
-
truncate tableを使って複数の...
-
既存データをINSERT文にして出...
-
2つの列からの最大値取得
-
SQLで、Join句で結合したテ...
-
SELECT INTOで一度に複数の変数...
-
エラーを起こす方法
-
SQLです!!教えてください。あ...
-
ACCESS VBAでSeekメソッドの処...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
timestampのデータはどのように...
-
エクセルvbaでpostgresに接続を...
-
SQLServer からのデータ移行(v...
-
SERIAL型の省略入力について
-
フラグをたてるってどういうこ...
-
SELECT INTOで一度に複数の変数...
-
【SQL】他テーブルに含まれる値...
-
sqlに記述できない文字
-
オラクルのUPDATEで複数テーブル
-
truncate tableを使って複数の...
-
既存データをINSERT文にして出...
-
UPDATEで既存のレコードに文字...
-
PostgreSQLのtimestamp型で時間...
-
エラーを起こす方法
-
SELECTした結果に行番号を求めたい
-
SQLで、Join句で結合したテ...
-
結合したテーブルをSUMしたい
-
テーブル名が可変の場合のクエ...
-
csvデータ不要列の削除をbatフ...
-
selectの単純繰り返し
おすすめ情報