0

私は3つ持っていますDM_EVENT.event_code

'DRL'
'CMP'
'WOV'

日付パラメーターを使用して、希望する最新の報告日 (この例では: '4/28/15') を選択し、その日付の時点を取得する必要がありSUM(DM_DAILYCOST.cost_per_item)ます。選択した日付を使用して問題ありません'CMP''WOV'

ただし、コードについては、 for'DRL'をプルする必要があります。SUM(DM_DAILYCOST.cost_per_item)DATEADD(d,-1,'4/28/15')

必要以上に難しくしていると思いますが、解決策に行き詰まっています。どんな洞察も大歓迎です!

SELECT cd_well.completion_well_id, 
       cd_well.spud_date, 
       cd_well.well_common_name, 
       dm_afe.afe_no, 
       dm_dailycost.activity_code, 
       dm_dailycost.activity_subcode, 
       dm_dailycost.cost_code, 
       Sum(dm_dailycost.cost_per_item) AS Expr1, 
       dm_dailycost.cost_subcode, 
       dm_event.date_ops_end, 
       dm_event.event_code 
FROM   dm_dailycost 
       INNER JOIN dm_afe 
               ON dm_dailycost.afe_id = dm_afe.afe_id 
       INNER JOIN dm_afe_event_link 
               ON dm_afe.afe_id = dm_afe_event_link.afe_id 
       INNER JOIN dm_event 
               ON dm_afe_event_link.well_id = dm_event.well_id 
                  AND dm_afe_event_link.event_id = dm_event.event_id 
                  AND dm_dailycost.well_id = dm_event.well_id 
                  AND dm_dailycost.event_id = dm_event.event_id 
       INNER JOIN cd_well 
               ON dm_event.well_id = cd_well.well_id 
       INNER JOIN cd_site 
               ON cd_well.site_id = cd_site.site_id 
       INNER JOIN dm_report_journal 
               ON dm_dailycost.afe_id = dm_report_journal.afe_id 
WHERE  ( dm_report_journal.date_report BETWEEN '4/1/15' AND '4/28/15' ) 
        OR ( dm_report_journal.date_report IS NULL ) 
GROUP  BY dm_dailycost.activity_subcode, 
          dm_dailycost.cost_code, 
          dm_event.date_ops_end, 
          cd_well.spud_date, 
          cd_well.completion_well_id, 
          dm_event.event_code, 
          dm_afe.afe_no, 
          dm_dailycost.cost_subcode, 
          dm_dailycost.activity_code, 
          cd_well.well_common_name, 
          dm_report_journal.date_report 
HAVING ( Sum(dm_dailycost.cost_per_item) IS NOT NULL )
4

1 に答える 1

0

必要なのは、WHEREステートメントの適切な条件だけです。'CMP'および'WOV'events at date'4/28/15''DRL'events at dateのみを選択する必要がありますDATEADD(d,-1,'4/28/15')

SELECT
 ...,
 SUM(dm_dailycost.cost_per_item) as Expr1,
 ...
FROM ...
INNER JOIN ...
...
WHERE
      dm_event.event_code in ('CMP', 'WOV') 
  AND dm_report_journal.date_report = '4/28/15'
  OR 
      dm_event.event_code = 'DRL'
  AND dm_report_journal.date_report = DATEADD(d,-1,'4/28/15')
GROUP BY ...

そして、クエリから HAVING ステートメントを削除します。

于 2015-04-28T19:05:51.537 に答える