All Downloads are FREE. Search and download functionalities are using the official Maven repository.

src.com.ibm.as400.access.DateTimeConverter Maven / Gradle / Ivy

///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: DateTimeConverter.java
//
// The source code contained herein is licensed under the IBM Public License
// Version 1.0, which has been approved by the Open Source Initiative.
// Copyright (C) 1997-2004 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
// 2008-05-21 @A1 Changes for *CURRENT when returning Date objects.  Adjust the
//            AS400 system time to the local client time.
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.beans.PropertyVetoException;
import java.io.IOException;
import java.io.UnsupportedEncodingException;
import java.util.Calendar;
import java.util.Date;
import java.util.Hashtable; //@CAA
import java.util.TimeZone; //@A1A


/**
 A utility for converting date/time values.
 The system API QWCCVTDT is used to convert a date and time value
 from one format to another format.

 @see AS400Date
 @see AS400Time
 @see AS400Timestamp
**/
public class DateTimeConverter
{
  private AS400 system_;
  private ProgramCall program_;
  private AS400Text text10_;

  private Calendar calendar_;
  //private Calendar calendarGMT_;
  private DateTime17Format format17_;
  //private DateTime16Format format16_;
  private TimeZone systemTimeZone_;  // the time zone for the IBM i server

  /**
   * Constructs a DateTimeConverter object.
   * @param system The system.
  **/
  public DateTimeConverter(AS400 system)
  {
    if (system == null)
      throw new NullPointerException("system");
    system_ = system;
    program_ = new ProgramCall(system_);
    text10_ = new AS400Text(10, system_.getCcsid(), system_);
    ///format17_ = new DateTime17Format(system_);
    //format16_ = new DateTime16Format(system_);
  }


  /**
   * Converts date and time values from the input format to the requested output format.
   * The system API QWCCVTDT (Convert Date and Time Format) is called to perform the conversion.
   * 

This method effectively just re-arranges the time format and returns it. * The input and output values are relative to the same time zone. * Therefore, no adjustments are made based on time-zone. * * @param data The date and time value to be converted. * @param inFormat The input date and time format. * Possible values are:

  • *CURRENT
  • *DTS
  • *JOB
  • *SYSVAL
  • *YMD
  • *YYMD
  • *MDY
  • *MDYY
  • *DMY
  • *DMYY
  • *JUL
  • *LONGJUL
* @param outFormat The output date and time format. * Possible values are:
  • *DTS
  • *JOB
  • *SYSVAL
  • *YMD
  • *YYMD
  • *MDY
  • *MDYY
  • *DMY
  • *DMYY
  • *JUL
  • *LONGJUL
  • *DOS
* @return The converted date and time value, left-justified in the array. * Refer to the specification for the QWCCVTDT API to determine how many of the * returned bytes are meaningful. * * @exception AS400SecurityException If a security or authority error * occurs. * @exception ErrorCompletingRequestException If an error occurs before * the request is completed. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with * the system. * @exception ObjectDoesNotExistException If the object does not exist on the system. **/ public byte[] convert(byte[] data, String inFormat, String outFormat) throws AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { return convert(data, inFormat, outFormat, null); } private byte[] convert(byte[] data, String inFormat, String outFormat, String timezone) throws AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if (data == null) throw new NullPointerException("data"); if (inFormat == null) throw new NullPointerException("inFormat"); if (outFormat == null) throw new NullPointerException("outFormat"); // Set up the parameters. // Design note: We don't need to use the optional parms, since we're not converting between different time zones. ProgramParameter[] parmList; if (timezone == null) { parmList = new ProgramParameter[5]; setRequiredParameters(parmList, data, inFormat, outFormat); } else { parmList = new ProgramParameter[10]; setRequiredParameters(parmList, data, inFormat, outFormat); setOptionalParameters(parmList, timezone); } // Set the program name and parameter list try { program_.setProgram("/QSYS.LIB/QWCCVTDT.PGM", parmList); } catch(PropertyVetoException pve) {} // Quiet the compiler program_.suggestThreadsafe(); //@A2A // Run the program if (!program_.run()) { // Note that there was an error Trace.log(Trace.ERROR, "DateTimeConverter call to QWCCVTDT failed."); // Show the messages AS400Message[] messageList = program_.getMessageList(); for (int i=0; iQWCCVTDT (Convert Date and Time Format) is called to perform the conversion. * @param data The date and time value to be converted. * The value is assumed to be relative to the IBM i system's time zone. * @param inFormat The format of the date and time value being provided. * Possible values are:
  • *CURRENT
  • *DTS
  • *JOB
  • *SYSVAL
  • *YMD
  • *YYMD
  • *MDY
  • *MDYY
  • *DMY
  • *DMYY
  • *JUL
  • *LONGJUL
* Note: When *CURRENT is specified, the data parameter is disregarded. * @return The converted date and time. * @exception AS400SecurityException If a security or authority error * occurs. * @exception ErrorCompletingRequestException If an error occurs before * the request is completed. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with * the system. * @exception ObjectDoesNotExistException If the object does not exist on the system. **/ public Date convert(byte[] data, String inFormat) throws AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if (data == null) throw new NullPointerException("data"); if (inFormat == null) throw new NullPointerException("inFormat"); // Use output format *YYMD which gives us a full Date: YYYYMMDD. byte[] converted = convert(data, inFormat, "*YYMD", null); // call QWCCVTDT Record rec = getFormat17().getNewRecord(converted); if (Trace.traceOn_) { Trace.log(Trace.DIAGNOSTIC, "DateTimeConverter record parsed from bytes: "+rec.toString()); } Calendar calendar = getCalendar(); calendar.set(Integer.parseInt(((String)rec.getField("year")).trim()), Integer.parseInt(((String)rec.getField("month")).trim())-1, Integer.parseInt(((String)rec.getField("day")).trim()), Integer.parseInt(((String)rec.getField("hour")).trim()), Integer.parseInt(((String)rec.getField("minute")).trim()), Integer.parseInt(((String)rec.getField("second")).trim())); calendar.set(Calendar.MILLISECOND, Integer.parseInt(((String)rec.getField("millisecond")).trim())); return calendar.getTime(); } // For testing and/or future enhancement: // /** // * Returns a converted Date object, relative to the GMT time zone. // * The system API QWCCVTDT (Convert Date and Time Format) is called to perform the conversion. // * @param data The date and time value to be converted. // * The value is assumed to be relative to the IBM i system's time zone. // * @param inFormat The format of the date and time value being provided. // * Possible values are: //
    //
  • *CURRENT //
  • *DTS //
  • *JOB //
  • *SYSVAL //
  • *YMD //
  • *YYMD //
  • *MDY //
  • *MDYY //
  • *DMY //
  • *DMYY //
  • *JUL //
  • *LONGJUL //
// * Note: When *CURRENT is specified, the data parameter is disregarded. // * @return The converted date and time. // * @exception AS400SecurityException If a security or authority error // * occurs. // * @exception ErrorCompletingRequestException If an error occurs before // * the request is completed. // * @exception InterruptedException If this thread is interrupted. // * @exception IOException If an error occurs while communicating with // * the system. // * @exception ObjectDoesNotExistException If the object does not exist on the system. // **/ // public Date convertGMT(byte[] data, String inFormat) // throws AS400SecurityException, // ErrorCompletingRequestException, // InterruptedException, // IOException, // ObjectDoesNotExistException // { // if (data == null) throw new NullPointerException("data"); // if (inFormat == null) throw new NullPointerException("inFormat"); // // // Use output format *YYMD which gives us a full Date: YYYYMMDD. // byte[] converted = convert(data, inFormat, "*YYMD", "*UTC"); // call QWCCVTDT // Record rec = getFormat17().getNewRecord(converted); // // if (Trace.traceOn_) // { // Trace.log(Trace.DIAGNOSTIC, "DateTimeConverter record parsed from bytes: "+rec.toString()); // } // // Calendar calendar = getCalendarGMT(); // calendar.set(Integer.parseInt(((String)rec.getField("year")).trim()), // Integer.parseInt(((String)rec.getField("month")).trim())-1, // Integer.parseInt(((String)rec.getField("day")).trim()), // Integer.parseInt(((String)rec.getField("hour")).trim()), // Integer.parseInt(((String)rec.getField("minute")).trim()), // Integer.parseInt(((String)rec.getField("second")).trim())); // calendar.set(Calendar.MILLISECOND, Integer.parseInt(((String)rec.getField("millisecond")).trim())); // // return calendar.getTime(); // } /** * Returns the converted date and time in a byte array. * @param date The Date object to be converted. * @param outFormat The format of the returned date and time value. * Possible values are:
  • *DTS
  • *JOB
  • *SYSVAL
  • *YMD
  • *YYMD
  • *MDY
  • *MDYY
  • *DMY
  • *DMYY
  • *JUL
  • *LONGJUL
* @return The converted date and time value, left-justified in the array. * The context of the value is the IBM i system's time zone. * Refer to the specification for the QWCCVTDT API to determine how many of the * returned bytes are meaningful. * * @exception AS400SecurityException If a security or authority error * occurs. * @exception ErrorCompletingRequestException If an error occurs before * the request is completed. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with * the system. * @exception ObjectDoesNotExistException If the object does not exist on the system. **/ public byte[] convert(Date date, String outFormat) throws AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if (date == null) throw new NullPointerException("date"); if (outFormat == null) throw new NullPointerException("outFormat"); byte[] data = dateToBytes(date); return convert(data, "*YYMD", outFormat, null); } // For testing and/or future enhancement: // /** // * Returns the converted date and time in a byte array, relative to the GMT time zone. // * @param date The Date object to be converted. // * @param outFormat The format of the returned date and time value. // * Possible values are: //
    //
  • *DTS //
  • *JOB //
  • *SYSVAL //
  • *YMD //
  • *YYMD //
  • *MDY //
  • *MDYY //
  • *DMY //
  • *DMYY //
  • *JUL //
  • *LONGJUL //
// * @return The converted date and time value, left-justified in the array. // * The context of the value is the GMT time zone. // * Refer to the specification for the QWCCVTDT API to determine how many of the // * returned bytes are meaningful. // * // * @exception AS400SecurityException If a security or authority error // * occurs. // * @exception ErrorCompletingRequestException If an error occurs before // * the request is completed. // * @exception InterruptedException If this thread is interrupted. // * @exception IOException If an error occurs while communicating with // * the system. // * @exception ObjectDoesNotExistException If the object does not exist on the system. // **/ // public byte[] convertGMT(Date date, String outFormat) // throws AS400SecurityException, // ErrorCompletingRequestException, // InterruptedException, // IOException, // ObjectDoesNotExistException // { // if (date == null) throw new NullPointerException("date"); // if (outFormat == null) throw new NullPointerException("outFormat"); // // byte[] data = dateToBytes(date); // return convert(data, "*YYMD", outFormat, "*UTC"); // "*UTC" == GMT timezone // } // Converts a Date value to an IBM i byte sequence in *YYMD format. private byte[] dateToBytes(Date date) throws AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { Calendar calendar = getCalendar(); calendar.setTime(date); // Start with *YYMD for conversion. Seems like a good format to use. Record rec = getFormat17().getNewRecord(); rec.setField("year", Integer.toString(calendar.get(Calendar.YEAR))); // Need to pad each number with 0s if necessary, so it will fill the format int month = calendar.get(Calendar.MONTH)+1; String monthStr = (month < 10 ? "0" : "") + month; rec.setField("month", monthStr); int day = calendar.get(Calendar.DAY_OF_MONTH); String dayStr = (day < 10 ? "0" : "") + day; rec.setField("day", dayStr); int hour = calendar.get(Calendar.HOUR_OF_DAY); String hourStr = (hour < 10 ? "0" : "") + hour; rec.setField("hour", hourStr); int minute = calendar.get(Calendar.MINUTE); String minuteStr = (minute < 10 ? "0" : "") + minute; rec.setField("minute", minuteStr); int second = calendar.get(Calendar.SECOND); String secondStr = (second < 10 ? "0" : "") + second; rec.setField("second", secondStr); int ms = calendar.get(Calendar.MILLISECOND); String msStr = (ms < 100 ? "0" : "") + (ms < 10 ? "0" : "") + ms; rec.setField("millisecond", msStr); if (Trace.traceOn_) { Trace.log(Trace.DIAGNOSTIC, "DateTimeConverter record parsed from Date: "+rec.toString()); } return rec.getContents(); } // Utility method. // Returns a Calendar object for the current system, set to the IBM i system's time zone. private final Calendar getCalendar() throws AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if (calendar_ == null) { // Create a Calendar object, based in the system's time zone. calendar_ = AS400Calendar.getGregorianInstance(getSystemTimeZone()); } else calendar_.clear(); return calendar_; } // For testing and/or future enhancement: // // Utility method. // // Returns a Calendar object set to the GMT time zone. // private final Calendar getCalendarGMT() // { // if (calendarGMT_ == null) { // // Create a Calendar object, based in the GMT time zone. // calendarGMT_ = AS400Calendar.getGregorianInstance(TimeZone.getTimeZone("GMT-0")); // } // else calendarGMT_.clear(); // return calendarGMT_; // } // Utility method. private synchronized DateTime17Format getFormat17() { if (format17_ == null) { format17_ = new DateTime17Format(system_); } return format17_; } /** * Returns a TimeZone object to represent the time zone for the system. * The TimeZone object will have the correct UTC offset for the system. * @return A TimeZone object representing the system's configured time zone setting. * @exception AS400SecurityException If a security or authority error * occurs. * @exception ErrorCompletingRequestException If an error occurs before * the request is completed. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with * the system. * @exception ObjectDoesNotExistException If the API used to retrieve the information does not exist on the system. **/ final TimeZone getSystemTimeZone() throws AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { if (systemTimeZone_ == null) { systemTimeZone_ = timeZoneForSystem(system_); } return systemTimeZone_; } // // These are the values shipped with the system. // See http://publib.boulder.ibm.com/infocenter/iseries/v7r1m0/index.jsp?topic=/rzati/rzatitimezone.htm // @CAA static String iTimeZoneTojavaTimeZoneMapping[][] = { {"Q0000UTC","UTC"}, {"Q0000GMT","GMT"}, {"Q0000GMT2","Europe/London"}, {"Q000GMT3","Europe/London"}, {"QN0100UTCS","GMT-1"}, {"QN0200UTCS","GMT-2"}, {"QN0300UTCS","GMT-3"}, {"QN0300UTC2","America/Sao_Paulo"}, {"QN0330NST","America/St_Johns"}, {"QN0330NST2","America/St_Johns"}, {"QN0330NST3","America/St_Johns"}, {"QN0330NST4","America/St_Johns"}, {"QN0400UTCS","GMT-4"}, {"QN0400AST","Atlantic/Bermuda"}, {"QN0400AST2","Atlantic/Bermuda"}, {"QN0400CLT","America/Santiago"}, {"QN0400UTC2","America/Caracas"}, {"QN0500UTCS","GMT-5"}, {"QN0500EST","America/New_York"}, {"QN0500EST2","GMT-5"}, {"QN0500EST3","America/New_York"}, {"QN0600UTCS","GMT-6"}, {"QN0600CST","America/Chicago"}, {"QN0600CST2","America/Chicago"}, {"QN0600CST3","America/Mexico_City"}, {"QN0600S","America/Chicago"}, {"QN0700UTCS","GMT-7"}, {"QN0700MST","America/Denver"}, {"QN0700MST2","America/Phoenix"}, {"QN0700MST3","America/Denver"}, {"QN0700MST4","America/Mazatlan"}, {"QN0700T","America/Denver"}, {"QN0800UTCS","GMT-8"}, {"QN0800PST","America/Los_Angeles"}, {"QN0800PST2","America/Los_Angeles"}, {"QN0800PST3","America/Tijuana"}, {"QN0800U","America/Los_Angeles"}, {"QN0900UTCS","GMT-9"}, {"QN0900AST","America/Anchorage"}, {"QN0900AST2","America/Anchorage"}, {"QN1000UTCS","GMT-10"}, {"QN1000HAST","America/Adak"}, {"QN1000HAS2","America/Adak"}, {"QN1000HST","Pacific/Honolulu"}, {"QN1100UTCS","GMT-11"}, {"QN1200UTCS","GMT-12"}, {"QP1245UTCS","Pacific/Chatham"}, {"QP1245UTC2","Pacific/Chatham"}, {"QP1200UTCS","GMT+12"}, {"QP1200NZST","Pacific/Auckland"}, {"QP1200NZS2","Pacific/Auckland"}, {"QP1200NZS3","Pacific/Auckland"}, {"QP1100UTCS","GMT+11"}, {"QP1000UTCS","GMT+10"}, {"QP1000AEST","Australia/Sydney"}, {"QP1000AES2","Australia/Sydney"}, {"QP0930ACST","Australia/Adelaide"}, {"QP0930ACS2","Australia/Adelaide"}, {"QP0900UTCS","GMT+9"}, {"QP0900JST","Asia/Tokyo"}, {"QP0900KST","Asia/Seoul"}, {"QP0900WIT","Asia/Jayapura"}, {"QP0800UTCS","GMT+8"}, {"QP0800AWST","Australia/Perth"}, {"QP0800AWS2","Australia/Perth"}, {"QP0800AWS3","Australia/Perth"}, {"QP0800BST","Asia/Shanghai"}, {"QP0800JIST","Asia/Hong_Kong"}, {"QP0800WITA","Asia/Ujung_Pandang"}, {"QP0700UTCS","GMT+7"}, {"QP0700WIB","Asia/Jakarta"}, {"QP0600UTCS","GMT+6"}, {"QP0600UTC2","Asia/Almaty"}, {"QP0600UTC3","Asia/Almaty"}, {"QP0530IST","Asia/Calcutta"}, {"QP0500UTCS","GMT+5"}, {"QP0500UTC2","Asia/Aqtobe"}, {"QP0500UTC3","Asia/Aqtobe"}, {"QP0400UTCS","GMT+4"}, {"QP0400UTC2","Asia/Aqtau"}, {"QP0400UTC3","Asia/Aqtau"}, {"QP0300MSK","Europe/Moscow"}, {"QP0300UTCS","GMT+3"}, {"QP0200UTCS","GMT+2"}, {"QP0200EET","Europe/Tallinn"}, {"QP0200EET2","GMT+2"}, {"QP0200EET3","Europe/Tallinn"}, {"QP0200SAST","Africa/Johannesburg"}, {"QP0100UTCS","GMT+1"}, {"QP0100CET","Europe/Zurich"}, {"QP0100CET2","Europe/Zurich"}, {"QP0100CET3","Europe/Zurich"}, {"QP0100CET4","Europe/Zurich"}, }; static Hashtable iTimeZoneToJavaTimeZoneHash = null; /** * Returns the name of the java timezone corresponding to the IBM i timezone. */ static String iTimeZoneToJavaTimeZone(String iTimeZone) { iTimeZone = iTimeZone.toUpperCase(); synchronized(iTimeZoneTojavaTimeZoneMapping) { if (iTimeZoneToJavaTimeZoneHash == null) { iTimeZoneToJavaTimeZoneHash = new Hashtable(); for (int i = 0; i < iTimeZoneTojavaTimeZoneMapping.length; i++) { iTimeZoneToJavaTimeZoneHash.put(iTimeZoneTojavaTimeZoneMapping[i][0],iTimeZoneTojavaTimeZoneMapping[i][1]); } } } return (String) iTimeZoneToJavaTimeZoneHash.get(iTimeZone); } /** * Returns a TimeZone object to represent the time zone for the specified system. * The TimeZone object will have the correct UTC offset for the system. * @param system The IBM i system. * @return A TimeZone object representing the time zone for the system. * @exception AS400SecurityException If a security or authority error * occurs. * @exception ErrorCompletingRequestException If an error occurs before * the request is completed. * @exception InterruptedException If this thread is interrupted. * @exception IOException If an error occurs while communicating with * the system. * @exception ObjectDoesNotExistException If the API used to retrieve the information does not exist on the system. * @see AS400#getTimeZone() **/ public static TimeZone timeZoneForSystem(AS400 system) throws AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException { // Using the UTC offset does not properly account for the use of daylight savings time. We use // the QTIMZON value to adjust for those areas that use daylight savings time. // try { SystemValue sv = new SystemValue(system, "QTIMZON"); String iTimeZone = ((String)sv.getValue()).trim(); // returns a value such as "-0500" @7XC String javaTimeZoneName = iTimeZoneToJavaTimeZone(iTimeZone); if (javaTimeZoneName != null) { return TimeZone.getTimeZone(javaTimeZoneName); } } catch (Exception e) { // Log the exception and continue Trace.log(Trace.ERROR, e); } // If the new method does not work, fall back to the old method of getting the timezone. // To obtain a standard ID for the time zone, simply concatenate "GMT" and the QUTCOFFSET value. String utcOffset = null; try { SystemValue sv = new SystemValue(system, "QUTCOFFSET"); utcOffset = (String)sv.getValue(); // returns a value such as "-0500" if (utcOffset == null || utcOffset.length() == 0) { if (Trace.traceOn_) { Trace.log(Trace.DIAGNOSTIC, "QUTCOFFSET is not set. Assuming server is in the same time zone as client application."); } return TimeZone.getDefault(); } else return TimeZone.getTimeZone("GMT" + utcOffset); } catch (RequestNotSupportedException e) // this won't happen { // ... but if it does happen, trace it and rethrow as a runtime exception Trace.log(Trace.ERROR, e); throw new InternalErrorException(InternalErrorException.UNEXPECTED_EXCEPTION, e); } catch (RuntimeException e) { // Note: We've observed the following error during testing: // java.lang.NullPointerException at java.util.TimeZone.parseCustomTimeZone() if (Trace.traceOn_) { Trace.log(Trace.WARNING, "["+e.toString()+"] Unable to determine time zone of system. " + "QUTCOFFSET value is " + utcOffset + ". " + "Assuming server is in the same time zone as client application."); } return TimeZone.getDefault(); } } // Utility method, for use by other Toolbox classes. // Trims-down a QWCCVTDT-generated EBCDIC date string, for use in a CL command parameter. // Depending on the specified format, this method strips extra leading and trailing digits that aren't expected by CL commands. static final String formatDateForCommandParameter(byte[] dateBytes, String dateFormat) throws UnsupportedEncodingException { int expectedLength = 0; String outVal = null; // Convert EBCDIC characters to a Unicode String. final String dateString = CharConverter.byteArrayToString(37, dateBytes); if (dateFormat.equals("*DTS")) expectedLength = 8; else if (dateFormat.equals("*YYMD") || dateFormat.equals("*MDYY") || dateFormat.equals("*DMYY") || dateFormat.equals("*LONGJUL")) { expectedLength = 17; // for details, refer to the API spec for QWCCVTDT } else if (dateFormat.equals("*MDY") || dateFormat.equals("*YMD") || dateFormat.equals("*DMY")) { // For these formats, CL commands expect 6 digits, with no leading "century guard digit". outVal = dateString.substring(1,7); } else if (dateFormat.equals("*JUL")) { // For *JUL, CL commands expect 5 digits, with no leading "century guard digit". outVal = dateString.substring(1,6); } else { expectedLength = 16; // for details, refer to the API spec for QWCCVTDT } if (outVal != null) return outVal; else { if (dateString.length() == expectedLength) return dateString; // no truncation needed else return dateString.substring(0,expectedLength); // truncate extra trailing digits } } /** * Specifies the 17-byte character date and time value format returned * on the QWCCVTDT API. **/ private static class DateTime17Format extends RecordFormat { private static final long serialVersionUID = 1L; DateTime17Format(AS400 system) { int ccsid = system.getCcsid(); AS400Text text2 = new AS400Text(2, ccsid, system); addFieldDescription(new CharacterFieldDescription(new AS400Text(4, ccsid, system), "year")); addFieldDescription(new CharacterFieldDescription(text2, "month")); addFieldDescription(new CharacterFieldDescription(text2, "day")); addFieldDescription(new CharacterFieldDescription(text2, "hour")); addFieldDescription(new CharacterFieldDescription(text2, "minute")); addFieldDescription(new CharacterFieldDescription(text2, "second")); addFieldDescription(new CharacterFieldDescription(new AS400Text(3, ccsid, system), "millisecond")); } } // /** // * Specifies the 16-byte character date and time value format returned // * on the QWCCVTDT API. //**/ //private static class DateTime16Format extends RecordFormat //{ // DateTime16Format(AS400 system) // { // int ccsid = system.getCcsid(); // AS400Text text2 = new AS400Text(2, ccsid, system); // addFieldDescription(new CharacterFieldDescription(new AS400Text(1, ccsid, system), "century")); // addFieldDescription(new CharacterFieldDescription(text2, "year")); // addFieldDescription(new CharacterFieldDescription(text2, "month")); // addFieldDescription(new CharacterFieldDescription(text2, "day")); // addFieldDescription(new CharacterFieldDescription(text2, "hour")); // addFieldDescription(new CharacterFieldDescription(text2, "minute")); // addFieldDescription(new CharacterFieldDescription(text2, "second")); // addFieldDescription(new CharacterFieldDescription(new AS400Text(3, ccsid, system), "millisecond")); // } //} }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy