The function
EXTRACT-DATE-TIME ( argument-1 argument-2 )
returns integer or character value.

For integer return value we use COMPUTE, for character value we use MOVE.

The return value of EXTRACT-DATE-TIME depends of argument-2
This doesn't work
MOVE FUNCTION EXTRACT-DATE-TIME (WS-DATE '@Y%m%d')
TO WS-DATE-YYYYMMDD-CHAR
because argument-2 = '%Y%m%d' consists of only numeric specifiers, so the
function returns integer
- see the ILE COBOL Reference p. 563 or this link
http://publib.boulder.ibm.com/infocenter/iadthelp/v7r0/index.jsp?topic=/com.ibm.etools.iseries.langref.doc/c0925395604.htm

however you can use first
COMPUTE WS-DATE-YYYYMMDD-NUM =
FUNCTION EXTRACT-DATE-TIME (WS-DATE '@Y%m%d')
and then
MOVE WS-DATE-YYYYMMDD-NUM TO WS-DATE-YYYYMMDD-CHAR
or use REDEFINE


Here is the example i tired:

PROCESS NOMONOPRC.

IDENTIFICATION DIVISION.
PROGRAM-ID. DATETIME4.
AUTHOR. MIKROM.
DATE-WRITTEN. 2012-11-29.
DATE-COMPILED.

ENVIRONMENT DIVISION.
CONFIGURATION SECTION.
SOURCE-COMPUTER. IBM-ISERIES.
OBJECT-COMPUTER. IBM-ISERIES.
SPECIAL-NAMES.
CURRENCY SIGN IS '$'
DECIMAL-POINT IS COMMA
.

DATA DIVISION.
WORKING-STORAGE SECTION.
01 WS-FIELDS.
05 WS-DATE FORMAT OF DATE IS '@Y%m%d'.
05 WS-DATE-YYYYMMDD-NUM PIC 9(8).
05 WS-DATE-YYYYMMDD-CHAR-RED REDEFINES WS-DATE-YYYYMMDD-NUM
PIC X(8).
05 WS-DATE-YYYYMMDD-CHAR PIC X(8).
05 WS-DATE-EUR PIC X(10).
05 WS-DATE-ISO PIC X(10).

PROCEDURE DIVISION.
MAIN-PARA.
INITIALIZE WS-FIELDS
* Get Current Date
MOVE FUNCTION CURRENT-DATE(1:8) TO WS-DATE

* - see ILE COBOL Reference, p.563:

* The EXTRACT-DATE-TIME function returns part of a date, time,
* or timestamp item.
* The function type is integer or alphanumeric. If argument-2
* is a keyword (such as MONTHS or DAYS), or consists of only
* numeric specifiers, an integer is returned.
* Otherwise, an alphanumeric data item is returned.

* Format:
*
* FUNCTION EXTRACT-DATE-TIME ( argument-1 argument-2 )

* This works:
* Compute numerical date in format of YYYYMMDD
COMPUTE WS-DATE-YYYYMMDD-NUM =
FUNCTION EXTRACT-DATE-TIME (WS-DATE '@Y%m%d')

* This doesn't work, because argument-2 = '%Y%m%d' consists of
* only numeric specifiers, so the function returns integer:
*
* Extract Date to String Format YYYYMMDD
* MOVE FUNCTION EXTRACT-DATE-TIME (WS-DATE '@Y%m%d')
* TO WS-DATE-YYYYMMDD-CHAR
*
* however this (or using REDEFINES) works:
MOVE WS-DATE-YYYYMMDD-NUM TO WS-DATE-YYYYMMDD-CHAR

* Extract Date to String Format DD.MM.YYYY
MOVE FUNCTION EXTRACT-DATE-TIME (WS-DATE '%d.%m.@Y')
TO WS-DATE-EUR

* Extract Date to String ISO Format YYYY-MM-DD
MOVE FUNCTION EXTRACT-DATE-TIME (WS-DATE '@Y-%m-%d')
TO WS-DATE-ISO

*
DISPLAY 'Numerical Date in Format YYYYMMDD : '
WS-DATE-YYYYMMDD-NUM
DISPLAY 'Character Date in Format YYYYMMDD : '
QUOTE WS-DATE-YYYYMMDD-CHAR-RED QUOTE
DISPLAY 'Character Date in Format YYYYMMDD : '
QUOTE WS-DATE-YYYYMMDD-CHAR QUOTE
DISPLAY 'Character Date in Format DD.MM.YYYY: '
QUOTE WS-DATE-EUR QUOTE
DISPLAY 'Character Date in Format YYYY-MM-DD: '
QUOTE WS-DATE-ISO QUOTE

*
GOBACK.


Output::

call DATETIME4
Numerical Date in Format YYYYMMDD : 20121129
Character Date in Format YYYYMMDD : '20121129'
Character Date in Format YYYYMMDD : '20121129'
Character Date in Format DD.MM.YYYY: '29.11.2012'
Character Date in Format YYYY-MM-DD: '2012-11-29'




From:
"Stone, Joel" <Joel.Stone@xxxxxxxxxx>
To:
"cobol400-l@xxxxxxxxxxxx" <cobol400-l@xxxxxxxxxxxx>
Date:
29.11.2012 16:37
Subject:
Re: [COBOL400-L] how to extract the most common date format - YYYYMMDD
Sent by:
cobol400-l-bounces@xxxxxxxxxxxx



Thanks for your response.

I am trying to move a DATE-data type to the most common file output format
of YYYYMMDD.

For some reason when the output specifier is @Y%m%d (=YYYYMMDD), then
COBOL is not able to use the MOVE verb to move it to an alpha field.
(Works great for @Y/%m/%d).

Apparently the only solution is to use COMPUTE, which isnt consistent with
ILE COBOL in that any other MOVE numeric to alpha works just fine.

COMPUTE works well, so I will use that.

It is frustrating that such a simple and common use - moving a date to a
column - works fine with slashes, but fails and requires a work-around
without slashes.

Every other OS & DB mgmt system handles this stuff consistently - at least
the ones that are still around:)


Thanks again.


-----Original Message-----
From: cobol400-l-bounces@xxxxxxxxxxxx [
mailto:cobol400-l-bounces@xxxxxxxxxxxx] On Behalf Of
MichaelQuigley@xxxxxxxxxx
Sent: Thursday, November 29, 2012 8:02 AM
To: cobol400-l@xxxxxxxxxxxx
Subject: Re: [COBOL400-L] how to extract the most common date format -
YYYYMMDD

Hi Joel,

I just got the digest from the mailing list. I use the date functions all

the time--they are definitely not full of bugs. We've found a couple of
oddities, but IBM quickly provided fixes for these.

Let me see if I understand correctly. Do I understand that what you want
is to translate from a field containing (for example), "20121128" and end
up with the format "2012-11-18"?

You can use EXTRACT-DATE-TIME, but I generally use CONVERT-DATE-TIME. The

EXTRACT function is intended to extract a portion of the date-time
field--e.g., the month or the year. If you simply are converting from one

format to another, ILE COBOL handles all the work for you. If you're
confident that ws-date always contains a date, try the following:

move ws-date to A0468X-DUE-DATE of AFTR

This is using the following working-storage assumptions:

01 ws-date format date '@Y%m@d'.

01 AFTR.
05 A0468X-DUE-DATE format date '@Y-%m-%d'.

If ws-date is not defined in working-storage as a FORMAT DATE field, then
you'll want to use the following:

move function CONVERT-DATE-TIME (ws-date DATE '@Y%m%d') to A0468X-DUE-DATE

of AFTR.

This example uses the following working-storage assumptions:

01 ws-date pic 9(8).

01 AFTR.
05 A0468X-DUE-DATE format date '@Y-%m-%d'.

If this isn't what you have in mind, post another message with the formats

of WS-DATE and A0468X-DUE-DATE. I'm convinced there's nothing with dates
that ILE COBOL can't handle.

Michael Quigley
Computer Services
The Way International
www.TheWay.org
419 753-1222


cobol400-l-bounces@xxxxxxxxxxxx wrote on 11/28/2012 04:53:57 PM:
----- Message from "Stone, Joel" <Joel.Stone@xxxxxxxxxx> on Wed, 28
Nov 2012 19:57:32 +0000 -----

To:

"'COBOL Programming on the iSeries/AS400'" <cobol400-l@xxxxxxxxxxxx>

Subject:

Re: [COBOL400-L] how to extract the most common date format - YYYYMMDD

Thanks but here is IBM doc example from "Websphere Development
Studio ILE COBOL reference" v5 SC09-2539-02:

MOVE FUNCTION EXTRACT-DATE-TIME (date-2 '%m/%d') to alphanum-1.

It's a stinker - I guess I will have to format as 2012/11/28 and
then SUBSTRING out the slashes.

It seems that once the slashes or spaces are gone from the edit
string, the compiler chokes because it thinks it is numeric.

Is it possible that it is impossible to pull the most common date
format? Does no one else use the cobol compiler with dates?


So here is the ugly code that I created:

move function EXTRACT-DATE-TIME (ws-date '@Y/%m/%d')
to ws-date-yyyy-mm-dd
string ws-date-yyyy-mm-dd (1:4)
ws-date-yyyy-mm-dd (6:2)
ws-date-yyyy-mm-dd (9:2)
delimited by size into A0468X-DUE-DATE of AFTR

Does anyone else use DATE functions in COBOL/ILE? Maybe the are
full of bugs??

As an Amazon Associate we earn from qualifying purchases.

This thread ...

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.