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

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

ただいまの
回答率

90.76%

  • SQL

    2232questions

    SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。

SQLで実働時間の合計を表示させたい

解決済

回答 1

投稿 編集

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

bd_

score 15

 前提・実現したいこと

SQLのSELECT文を用いて実働時間の合計を表示させたいです。

開始時間 終了時間 実働時間 合計
08:30 19:30 10 25
09:00 17:30 7.5
09:00 17:30 7.5

 発生している問題・エラーメッセージ

実際の合計時間と表示されている合計時間が異なる

開始時間 終了時間 実働時間 合計
08:30 19:30 10 53.99.....
09:00 17:30 7.5 41.50.....
09:00 17:30 7.5 41.50.....

 該当のソースコード

SELECT 
to_char(kj.開始時間,'hh24:mi') as 開始時間,
to_char(kj.終了時間,'hh24:mi') as 終了時間,
(kj.終了時間 - kj.開始時間) * 24 - 1 as 実働時間,
(select sum(kj.終了時間 - kj.開始時間) * 24 - 1 from 社員2 s) as 合計
from 社員2 s

inner join 勤務予定時間 k
on s.社員ID = k.社員ID
inner join 勤務時間 kj
on s.社員ID = kj.社員ID
and to_char(k.年月,'yyyy-mm') = to_char(kj.年月日,'yyyy-mm')
where k.社員ID = '0001'
and   k.年月 = '2018-04-01 00:00:00';

 試したこと

実働時間の合計を副問い合わせで表現した。

 補足情報(FW/ツールのバージョンなど)

Oracle SQL Developer

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • mts10806

    2018/06/06 13:11

    「テーブル定義」では伝わらない悲しさ。 それぞれのデータの型、サイズなどが書いてあるものです。https://consulting.jxyz.info/419250224/

    キャンセル

  • m6u

    2018/06/06 13:23

    日付とか時刻とかデータ型が何になっているかによってクエリーの作りも変わる重要な要素なのにね。SQL Developerで該当TableでColumnタブがどう表示されているかを掲載するだけでもいいのだけど。

    キャンセル

  • sazi

    2018/06/06 13:43

    msts10806 さん 取り敢えず演算結果とかは確認されていたようなので、属性は関係ないかなと思って回答したんですが、啓蒙活動としてはそれらが揃うまで回答は控えた方がいいんですかね。

    キャンセル

回答 1

checkベストアンサー

+2

相関副問合せになっていないので、全員分の実働時間の合計が算出されています。

社員2の集計の単位項目をidとした場合、以下のようにします

SELECT  id
      , to_char(kj.開始時間,'hh24:mi') as 開始時間
      , to_char(kj.終了時間,'hh24:mi') as 終了時間
      , (kj.終了時間 - kj.開始時間) * 24 - 1 as 実働時間
      , (select sum(kj.終了時間 - kj.開始時間) * 24 - 1 from 社員2 where id=kj.id) as 合計
FROM    社員2 kj


※実際には集計期間の単位(例えば月ごと)があると思いますので、相関問い合わせのwhere 条件にはそれらも含める事になるかと思います。

追記

質問のSQL文が修正されたので、それに合わせて修正。
※joinなどの結合項目など、(インデックスがあれば適用されるように)最適化しています。

SELECT  to_char(kj.開始時間,'hh24:mi') as 開始時間
      , to_char(kj.終了時間,'hh24:mi') as 終了時間
      ,(kj.終了時間 - kj.開始時間) * 24 - 1 as 実働時間
      ,(select sum(終了時間 - 開始時間) * 24 - 1 from 勤務時間 
        where 社員ID=kj.社員ID and to_char(年月日,'yyyy-mm')=to_char(k.年月,'yyyy-mm')
       ) as 合計
from  社員2 s
      inner join 勤務予定時間 k
      on    s.社員ID = k.社員ID
      inner join 勤務時間 kj
      on    k.社員ID = kj.社員ID
       and  to_char(k.年月,'yyyy-mm') = to_char(kj.年月日,'yyyy-mm')
where k.社員ID = '0001'
 and  k.年月 = '2018-04-01 00:00:00'


※テーブル定義やインデックスに定義情報があれば、もっと適切な記述となる箇所があるかもしれません

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

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

  • ただいまの回答率 90.76%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

  • 解決済

    テーブルの結合について(複数キー)

    前提・実現したいこと railsを使用しています。 【カテゴリテーブル】 id|name| 1|野菜| 2|果物| 3|炭水化物| 【買い物テーブル】

  • 解決済

    mysql where句 複数テーブルで複数条件の摘出

    お世話になります。  mysqlを二日前から勉強し始めた超初心者です。  まったくの初心者なのですが、自力での解決が難しそうなので、教えて下さい。  <現状の問題点>

  • 解決済

    重複したデータを抽出させないSQL

    同一テーブル、または別テーブルに重複したデータが存在していれば、 それを抽出するCSVリストを作成したいと考えております。 ID SEI MEI 010 山田 太郎 02

  • 解決済

    PHPのforeach文について

    前提・実現したいこと echo $course_name_array[2]; の下のforeach文を正常に動作させたいです 発生している問題・エラーメッセージ Notice:

  • 解決済

    SQL内で抽出後のデータを修正する方法

    下記のSQL文に対して、WHERE句の抽出条件によって、 Cの値が重複していれば、一行にしてCの値をNULLに変えたいです。 どの様に書き直せばいいでしょうか? ご教授いただければ

  • 解決済

    Aceessで1つのテーブルから複数JOINしたい

     前提 初めて質問させていただきます。AccessでSQLを初めて触っているものです。よって、ところどころ言葉の使い方がおかしい部分があるかもしれません。その部分含めご指摘いただけ

  • 解決済

    SQLの結合について

    テーブルA |A1|A2| |1 |3| |2||4| テーブルB |B1||B2| |1||2| |3||NULL| 1.SQL SELECT A1,A2,B1,B2  FRO

  • 解決済

    GROUP BYで絞った結果をさらに絞る方法

    年月ごとの総数を求めたかったのですが、GROUP BYを利用すると,まとめた総数からさらに条件をつけて絞った条件総数がわからず困っています。 SELECT DATE_FORMA

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

  • SQL

    2232questions

    SQL(Structured Query Language)は、リレーショナルデータベース管理システム (RDBMS)のデータベース言語です。大きく分けて、データ定義言語(DDL)、データ操作言語(DML)、データ制御言語(DCL)の3つで構成されており、プログラム上でSQL文を生成して、RDBMSに命令を出し、RDBに必要なデータを格納できます。また、格納したデータを引き出すことも可能です。