Title: RE: Sql question

John,

I see two options.  Both include a cross reference table with every date in it. 

1.  Outer join the dates table with the data table and nvl after the sum to replace nulls with 0's.

Or

2.  Simply union-all your query as it stands right now with


SELECT  DATE_FIELD, 0
 FROM           DATES_TABLE

and summarize over that dataset.

I think the union all  (option #2) will be faster. 

HTH
Lisa Koivu
Data Bored Administrator
Ft. Lauderdale, FL, USA


    -----Original Message-----
    From:   Shaw, John B [SMTP:[EMAIL PROTECTED]]
    Sent:   Friday, June 29, 2001 2:37 PM
    To:     Multiple recipients of list ORACLE-L
    Subject:        Sql question

    I want to get every date between two user entered date's whether or not it
    exists in the table and then the quantity of data for the date if any
    exists.
    My table t1 has date and quantity values (may be more than one quantity
    field per date)
    and I want 0 for all dates in the range where no data exists.
    Is there a sql to get this without making some kind of date table?
    so if the user enters 03/02/01 and 03/06/01 they get.
    03/02/01        10
    03/03/01        1
    03/04/01        0
    03/05/01        0
    03/06/01        8
    They want to load into a spreadsheet.
    tia.
    --
    Please see the official ORACLE-L FAQ: http://www.orafaq.com
    --
    Author: Shaw, John B
      INET: [EMAIL PROTECTED]

    Fat City Network Services    -- (858) 538-5051  FAX: (858) 538-5051
    San Diego, California        -- Public Internet access / Mailing Lists
    --------------------------------------------------------------------
    To REMOVE yourself from this mailing list, send an E-Mail message
    to: [EMAIL PROTECTED] (note EXACT spelling of 'ListGuru') and in
    the message BODY, include a line containing: UNSUB ORACLE-L
    (or the name of mailing list you want to be removed from).  You may
    also send the HELP command for other information (like subscribing).

Reply via email to