× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



Dave

Others (and I) have mentioned that it is wise not to apply a function or conversion to a column of the table - this almost always results in a full table scan, because the function has to be evaluated for every record in the table. Charles suggested a BETWEEN predicate and using Alan Campin's UDFs. I'm not sure if a BETWEEN is needed - I think the OP wanted a "greater than", so the expression need be calculated only once - of course, the SQL process might know how to optimize that, IIRC.

Basic principle - avoid at almost any cost, if possible, applying functions to columns in comparisons.

Cheers
Vern

On 6/28/2016 4:19 PM, dlclark@xxxxxxxxxxxxxxxx wrote:
"MIDRANGE-L" <midrange-l-bounces@xxxxxxxxxxxx> wrote on 06/28/2016
04:50:46 PM:
I have what I think is a fairly simple SQL question but it's baffling
me.
I have a field in a file that is a date (field is in packed format). The
date in the field looks like this: 1160628. The need is to only grab
records from this file that go back 3 months from the first day of the
current month, so in this case I'd only want records with a date greater
than 1160301. This also needs to work if when subtracting the 3 months
I
had to go across multiple years. I know I can do a formula something
like
this:

(CURRENT_DATE - (DAY(CURRENT_DATE)-1) DAYS - 3 MONTH)


But I'm not sure how to use the packed numeric date field I have to get
there. Any thoughts would be greatly appreciated. Thanks!
You can convert your packed-decimal field to a date as follows.
What this does is change your CYYMMDD field to a YYYYMMDD value before
rendering it as character data for input to the TIMESTAMP_FORMAT()
function and then into the DATE() function specifying the 'YYYYMMDD'
format option.

DATE(TIMESTAMP_FORMAT(CHAR(myfield+19000000), 'YYYYMMDD'))

Naturally, it would be better to do this when modernizing the file
into a new SQL table.

Sincerely,

Dave Clark


As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.