×
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.
Dennis Lovelady wrote:
Of course those literals would both need to be '1940-01-01' to
be in the one hundred year window; oops :-)
However that CASE would not handle a date overflow and could
replace many valid dates. Thus actually ensuring the transfer
function uses a four-digit-year is still preferable.
No oops necessary, since the solution was presented only as a
means of getting around the limitations of Excel, which by the
way were misstated.
The apparent lower limit for Excel dates is 1/1/1900.
Any value under 1940 is still an underflow; i.e. the value
0001-01-01 is failing with underflow in the scenario by the OP, so
too will any value less than 1940-01-01. Thus an attempt to replace
only values prior to 1900 will still leave the transfer failing for
any dates between 1900-01-01 and 1939-12-31 inclusive.
Replacing only the value '0001-01-01' would ensure that any dates
outside of the valid window would still fail; i.e. continue to
diagnose as an error, anything other than the *LOWVAL, which is
probably better than possibly corrupting the dates by resetting
a valid date to a consistent yet wrong date.
Umm... I think you'll find that the system has already validated
any date field (I mean if the DB knows that it's a date), and
that nothing will fall "outside the valid window," whatever that
is.
All of the date values inserted [with mapping] and stored in the
database file will indeed be valid dates. There is however, a 100
year window for which a date can not be retrieved from the file
[regardless that the datum represents a valid date] when the
application has failed to request to use a four-digit-year during
that retrieval. The 100 year window for retrieval of date data type
values from the database is 1940-01-01 to 2039-12-31. Any value
outside of that range, when a two-digit-year representation is in
effect, will generate a /date overflow/ or /date underflow/ error.
This requirement exists because the database knows there is no
guarantee of a /round trip/ of a date value such as 11/11/11 except
within any any one-hundred epoch. If the database were to allow one
to retrieve 11/11/11 to represent 1911/11/11, then when that same
value was inserted, it would then represent 2011/11/11 which means
the meaning was _corrupted_ as I had alluded. Thus the error is
issued due to ambiguity inherent in two-digit-year formats.
I think you will also find that there are no *LOWVAL dates in
these fields. I believe that if you debug an RPG program that
attempts to set a date to *LOVAL, it will actually be set to
0001-01-01.
I was using *LOWVAL for a date, as a synonym for the date value
0001-01-01.
I was trying to suggest that all date values outside of the
supported 100 year window should be /handled/ in any attempt at
resolution to the scenario presented by the OP. In replacing only
the date value 0001-01-01, that would /handle/ the situation by
ensuring all values other than 0001-01-01 would be replace, while
ensuring all out-of-range dates would still cause the SQL0181; IMO a
much better approach than possibly changing a date like 1911-10-18
into an ambiguously-valid date like 1940-01-01 or 2039-12-31 [or any
value betwixt].
Regards, Chuck
As an Amazon Associate we earn from qualifying purchases.
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.