View: po_expnse_consol_all_view

Columns
  Column Name Data Type
1.   line_id tinyint
2.   po_expense_line_descriptor_key decimal(15)
3.   po_expense_line_key decimal(15)
4.   orig_po_key decimal(15)
5.   line_po_key decimal(15)
6.   owning_po_key decimal(15)
7.   pr_expense_line_descriptor_key decimal(15)
8.   pr_key decimal(15)
9.   account_key decimal(15)
10.   organization_key decimal(15)
11.   reference varchar(25)
12.   description varchar(128)
13.   project_key decimal(15)
14.   task_key decimal(15)
15.   expense_type_key decimal(15)
16.   person_key decimal(15)
17.   closed_date timestamp
18.   begin_date timestamp
19.   end_date timestamp
20.   required_by_date timestamp
21.   internal_comments varchar(2000)
22.   external_comments varchar(2000)
23.   vi_overage char(1)
24.   amount decimal(38,2)
Table/Column Dependencies
Table Column
po_expense_line amount
  begin_date
  end_date
  external_comments
  internal_comments
  po_expense_line_descriptor_key
  po_expense_line_key
  po_key
  required_by_date
  vi_overage
po_expense_line_descriptor account_key
  closed_date
  description
  expense_type_key
  line_id
  organization_key
  orig_po_key
  person_key
  po_expense_line_descriptor_key
  po_key
  pr_expense_line_descriptor_key
  project_key
  reference
  task_key
purchase_order document_number
  mod_number
  po_key
  pr_key
  status
SQL Server Create Statement
create view po_expnse_consol_all_view
as
select
    descr.line_id,
    descr.po_expense_line_descriptor_key,
    line.po_expense_line_key,
    descr.orig_po_key,
    line.po_key as line_po_key,
    descr.po_key as owning_po_key,
    descr.pr_expense_line_descriptor_key,
    po.pr_key,
    descr.account_key,
    descr.organization_key,
    descr.reference,
    descr.description,
    descr.project_key,
    descr.task_key,
    descr.expense_type_key,
    descr.person_key,
    descr.closed_date,
    line.begin_date,
    line.end_date,
    line.required_by_date,
    line.internal_comments,
    line.external_comments,
    line.vi_overage,
    summary.amount
from po_expense_line_descriptor descr
join po_expense_line line on line.po_expense_line_descriptor_key = descr.po_expense_line_descriptor_key
join purchase_order po on po.po_key = line.po_key
join (
    select line.po_expense_line_descriptor_key,
        max(po.mod_number) mod_number,
        max(case when po.mod_number is null then document_number else null end) document_number,
        sum(line.amount) amount
    from po_expense_line line
    join purchase_order po on po.po_key = line.po_key
        and po.status != 'CANCELED'
    group by line.po_expense_line_descriptor_key
    ) summary on summary.po_expense_line_descriptor_key = line.po_expense_line_descriptor_key
where summary.mod_number = po.mod_number
    and (
        (
            summary.document_number is null
            and summary.mod_number = po.mod_number
            )
        or summary.document_number = po.document_number
        )