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

com.ibm.as400.access.AS400JDBCArray Maven / Gradle / Ivy

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//
//JTOpen (IBM Toolbox for Java - OSS version)                                 
//
//Filename: AS400JDBCArray.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) 2009-2009 International Business Machines Corporation and     
//others. All rights reserved.                                                
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;

import java.io.Serializable;
import java.math.BigDecimal;
import java.math.BigInteger;
import java.sql.*;




// @array new class
/**
 * AS400JDBCArray is an implementation of java.sql.Array and contains an array
 * of JDBC data. It provides mapping in the Java programming language for the
 * SQL type ARRAY. Currently AS400JDBCArray is only supported by
 * using stored procedure input/output parameters.
 */

public class AS400JDBCArray implements Array, Serializable {

  private Object[] data_; // !!!Note this array may hold generic data such as
                          // Integers,
  // or may hold special "output" data in form of SQLData
  // objects. This is needed for managing efficient
  // ArrayResultSet data conversion. But we don't want a user
  // generated AS400JDBCArray (via Connection create method)
  // to contain SQLData[] since at that point in time, we
  // don't really know the prepare/describe data attributes.
  // And then we would have to convert data twice, once in
  // AS400JDBCArray and once in SQLArray.

  private String typeName_; // typename is supplied by user at creation or from
                            // hostserver prepare/describe
  int typeCode_; // type from from java.sql.Types
  // protected int type_;
  private int vrm_;
  transient private AS400JDBCConnection con_;

  // This is just a reference to the SQLData type that this array contains. It
  // is not
  // a reflection from a prepare/describe, but is
  // just used for any potential temporary conversion needed before final
  // conversion
  // before setting in actual PreparedStatement going to hostserver
  // (ie Array.getResultSet() -> ars.getString(1))
  transient private SQLData contentTemplate_;

  // if data_[0] contains an SQLData, then contentTemplate_ will point to it!
  private boolean isSQLData_ = false; // true if data[0]_ == SQLData

  AS400JDBCArray() {
  } // restrict

  /**
   * Constructs an AS400JDBCArray object.
   * 
   * @param typeName
   *          The typeName.
   * @param data
   *          The data.
   * @param vrm
   *          The version.
   * @param con
   *          Connection.
   **/
  AS400JDBCArray(String typeName, Object[] data, int vrm,
      AS400JDBCConnection con) throws SQLException {
    /*
     * typeName is used to create a dummy SQLData object used for potential data
     * conversion when data[] is not of type SQLData[]. Pass in a connection if
     * the Object[] data is not SQLData. This will use connection's default
     * conversion data. Throws exception if typeName is not valid per
     * SQLDataFactory.
     */
    typeCode_ = JDUtilities.getTypeCode(typeName);
    typeName_ = JDUtilities.getTypeName(typeCode_);
    vrm_ = vrm;

    // check if array of SQLData
    // since values can be null, don't check if data_[0] is instance of SQLData
    if (data instanceof SQLData[]) {
      isSQLData_ = true;
      data_ = data;
    } else {
      // in this case, we will create our own temporary SQLData object used for
      // potential conversion in AS400JDBCArrayResultSet
      isSQLData_ = false;
      // Set the data using our own routines to get the type correct in the
      // object. This will set data_
      setArray(data);
    }

    con_ = con; // @arrayrs
    contentTemplate_ = null; 
    for (int  i = 0; isSQLData_ && (contentTemplate_ == null) && (i < data_.length); i++) { 
      if (data_[i] != null)  { 
        contentTemplate_ = (SQLData) data_[i];
      }
    }
    if (contentTemplate_ == null ) { 
      contentTemplate_ = SQLDataFactory.newData(typeName, 1, 1, 1, 37, null,
          vrm_, (con == null ? null : con.getProperties())); // @array
    // allow max for local conversion only since it is not associated with a
    // column on hostserver yet
    }
  }

  /**
   * This method will free the internal memory that this object holds.
   * @throws SQLException  If a database error occurs.
   **/
  synchronized public void free() throws SQLException {
    // na no locators can be in arrays.
  }

  /**
   * Retrieves the SQL type name of the elements in the array designated by this
   * Array object. If the elements are a built-in type, it returns
   * the database-specific type name of the elements. If the elements are a
   * user-defined type (UDT), this method returns the fully-qualified SQL type
   * name.
   * 
   * @return database-specific name for a built-in base type; or the
   *         fully-qualified SQL type name for a base type that is a UDT
   * @exception SQLException
   *              if an error occurs while attempting to access the type name
   * 
   */
  public String getBaseTypeName() throws SQLException {
    return typeName_;
  }

  /**
   * Retrieves the JDBC type of the elements in the array designated by this
   * Array object.
   * 
   * @return a constant from the class {@link java.sql.Types} that is the type
   *         code for the elements in the array designated by this
   *         Array object
   * @exception SQLException
   *              if an error occurs while attempting to access the base type
   * 
   */
  public int getBaseType() throws SQLException {

    return contentTemplate_.getType();

  }

  /**
   * Retrieves the contents of the SQL ARRAY value designated by
   * this Array object in the form of an array in the Java
   * programming language. This version of the method getArray uses
   * the type map associated with the connection for customizations of the type
   * mappings.
   * 
   * @return an array in the Java programming language that contains the ordered
   *         elements of the SQL ARRAY value designated by this
   *         Array object
   * @exception SQLException
   *              if an error occurs while attempting to access the array
   * 
   */
  synchronized public Object getArray() throws SQLException {
    // data could be sqlData if output from query or input Ojbects such as
    // Integer or Clob

    return getArrayX(1, data_.length);
  }

  /**
   * Retrieves a slice of the SQL ARRAY value designated by this
   * Array object, beginning with the specified index
   * and containing up to count successive elements of the SQL
   * array. This method uses the type map associated with the connection for
   * customizations of the type mappings.
   * 
   * @param index
   *          the array index of the first element to retrieve; the first
   *          element is at index 1
   * @param count
   *          the number of successive SQL array elements to retrieve
   * @return an array containing up to count consecutive elements
   *         of the SQL array, beginning with element index
   * @exception SQLException
   *              if an error occurs while attempting to access the array
   */
  synchronized public Object getArray(long index, int count)
      throws SQLException {

    if (index <= 0)
      JDError.throwSQLException(JDError.EXC_BUFFER_LENGTH_INVALID, "" + index);
    if (count < 0)
      JDError.throwSQLException(JDError.EXC_BUFFER_LENGTH_INVALID, "" + count);
    if (index > data_.length)
      JDError.throwSQLException(JDError.EXC_BUFFER_LENGTH_INVALID, "" + index);
    if ((index + count) > (data_.length + 1))
      JDError.throwSQLException(JDError.EXC_BUFFER_LENGTH_INVALID, index + "+"
          + count);

    return getArrayX(index, count);
  }

  /**
   * Retrieves Array ResultSet that contains the elements of the SQL
   * ARRAY value designated by this Array object. The
   * result set contains one row for each array element, with two columns in
   * each row. The second column stores the element value; the first column
   * stores the index into the array for that element (with the first array
   * element being at index 1). The rows are in ascending order corresponding to
   * the order of the indices.
   * 
   * @return an Array ResultSet object containing one row for each of the
   *         elements in the array designated by this Array object,
   *         with the rows in ascending order based on the indices.
   * @exception SQLException
   *              if an error occurs while attempting to access the array
   */
  synchronized public ResultSet getResultSet() throws SQLException {

    AS400JDBCArrayResultSet rs = new AS400JDBCArrayResultSet(data_,
        contentTemplate_, isSQLData_, getBaseType(), vrm_);
    if (JDTrace.isTraceOn())
      JDTrace.logInformation(this, "getResultSet");
    return rs;
  }

  /**
   * Retrieves a result set holding the elements of the subarray that starts at
   * index index and contains up to count successive
   * elements. This method uses the connection's type map to map the elements of
   * the array if the map contains an entry for the base type. Otherwise, the
   * standard mapping is used.
   * 

* The result set has one row for each element of the SQL array designated by * this object, with the first row containing the element at index * index. The result set has up to count rows in * ascending order based on the indices. Each row has two columns: The second * column stores the element value; the first column stores the index into the * array for that element. * * @param index * the array index of the first element to retrieve; the first * element is at index 1 * @param count * the number of successive SQL array elements to retrieve * @return a ResultSet object containing up to count * consecutive elements of the SQL array designated by this * Array object, starting at index index. * @exception SQLException * if an error occurs while attempting to access the array * */ synchronized public ResultSet getResultSet(long index, int count) throws SQLException { int intIndex = (int) index - 1; // make 0 based Object[] retArry = new Object[count]; // !!!!here also if (data_.length > 0) { for (int x = 0; x < count; x++) { retArry[x] = data_[x + intIndex]; // just return values that were set by // user with no conversion } } else { retArry = data_; // length 0 or null value } AS400JDBCArrayResultSet rs = new AS400JDBCArrayResultSet(retArry, contentTemplate_, isSQLData_, getBaseType(), vrm_); if (JDTrace.isTraceOn()) JDTrace.logInformation(this, "getResultSet"); return rs; } /** * Retrieves a result set that contains the elements of the SQL * ARRAY value designated by this Array object. This * method uses the specified map for type map customizations * unless the base type of the array does not match a user-defined type in * map, in which case it uses the standard mapping. This version * of the method getResultSet uses either the given type map or * the standard mapping; it never uses the type map associated with the * connection. *

* The result set contains one row for each array element, with two columns in * each row. The second column stores the element value; the first column * stores the index into the array for that element (with the first array * element being at index 1). The rows are in ascending order corresponding to * the order of the indices. * * @param map * contains the mapping of SQL user-defined types to classes in the * Java programming language * @return a ResultSet object containing one row for each of the * elements in the array designated by this Array object, * with the rows in ascending order based on the indices. * @exception SQLException * if an error occurs while attempting to access the array * */ synchronized public Object getArray(java.util.Map map) throws SQLException { JDError.throwSQLException(this, JDError.EXC_FUNCTION_NOT_SUPPORTED,"getArray(java.util.Map)"); return null; } /** * Retreives a slice of the SQL ARRAY value designated by this * Array object, beginning with the specified index * and containing up to count successive elements of the SQL * array. *

* This method uses the specified map for type map customizations * unless the base type of the array does not match a user-defined type in * map, in which case it uses the standard mapping. This version * of the method getArray uses either the given type map or the * standard mapping; it never uses the type map associated with the * connection. * * @param index * the array index of the first element to retrieve; the first * element is at index 1 * @param count * the number of successive SQL array elements to retrieve * @param map * a java.util.Map object that contains SQL type names * and the classes in the Java programming language to which they are * mapped * @return an array containing up to count consecutive elements * of the SQL ARRAY value designated by this * Array object, beginning with element * index * @exception SQLException * if an error occurs while attempting to access the array * */ synchronized public Object getArray(long index, int count, java.util.Map map) throws SQLException { JDError.throwSQLException(this, JDError.EXC_FUNCTION_NOT_SUPPORTED,"getArray(long,int,Java.util.Map)"); return null; } /** * Retrieves a result set that contains the elements of the SQL * ARRAY value designated by this Array object. This * method uses the specified map for type map customizations * unless the base type of the array does not match a user-defined type in * map, in which case it uses the standard mapping. This version * of the method getResultSet uses either the given type map or * the standard mapping; it never uses the type map associated with the * connection. *

* The result set contains one row for each array element, with two columns in * each row. The second column stores the element value; the first column * stores the index into the array for that element (with the first array * element being at index 1). The rows are in ascending order corresponding to * the order of the indices. * * @param map * contains the mapping of SQL user-defined types to classes in the * Java programming language * @return a ResultSet object containing one row for each of the * elements in the array designated by this Array object, * with the rows in ascending order based on the indices. * @exception SQLException * if an error occurs while attempting to access the array * */ synchronized public ResultSet getResultSet(java.util.Map map) throws SQLException { JDError.throwSQLException(this, JDError.EXC_FUNCTION_NOT_SUPPORTED,"getResultSet(java.util.Map)"); return null; } /** * Retrieves a result set holding the elements of the subarray that starts at * index index and contains up to count successive * elements. This method uses the specified map for type map * customizations unless the base type of the array does not match a * user-defined type in map, in which case it uses the standard * mapping. This version of the method getResultSet uses either * the given type map or the standard mapping; it never uses the type map * associated with the connection. *

* The result set has one row for each element of the SQL array designated by * this object, with the first row containing the element at index * index. The result set has up to count rows in * ascending order based on the indices. Each row has two columns: The second * column stores the element value; the first column stroes the index into the * array for that element. * * @param index * the array index of the first element to retrieve; the first * element is at index 1 * @param count * the number of successive SQL array elements to retrieve * @param map * the Map object that contains the mapping of SQL type * names to classes in the Java(tm) programming language * @return a ResultSet object containing up to count * consecutive elements of the SQL array designated by this * Array object, starting at index index. * @exception SQLException * if an error occurs while attempting to access the array * */ synchronized public ResultSet getResultSet(long index, int count, java.util.Map map) throws SQLException { JDError.throwSQLException(this, JDError.EXC_FUNCTION_NOT_SUPPORTED,"getResultSet(long,int,java.util.Map)"); return null; } // --------------------jdbc internal methods----------------- /* * Get part or all of array. index is 1-based. If array content is output from * database, then convert data via getObject(). */ private Object getArrayX(long index, int count) throws SQLException { int intIndex = (int) index - 1; // make 0 based if ( isSQLData_) // @nullelem { // create array of same type as data_ Class dummySQLXType = null; // @nullelem try { String className = contentTemplate_.getJavaClassName(); // For some classes, use the superclass @G7A if (className.equals("com.ibm.as400.access.AS400JDBCBlob")) { className = "java.sql.Blob"; } dummySQLXType = Class.forName(className); // data_[0]).getObject(); // //returns // column's // rs.getX() // type // (ie // Integer, // String, // etc) // //@nullelem } catch (Exception e) { try { dummySQLXType = Class.forName("java.lang.Object"); } catch (Exception ee) { dummySQLXType = null; } } Object retArry = java.lang.reflect.Array .newInstance(dummySQLXType, count); for (int x = 0; x < count; x++) { if (data_[x + intIndex] != null) { Object o = ((SQLData) data_[x + intIndex]).getObject(); ((Object[]) retArry)[x] = o; // based // on // SQLData } else ((Object[]) retArry)[x] = null; // @nullelem } return retArry; // returns array of types such as Ingeter[] etc } else if ((data_.length > 0) && !isSQLData_) { Object retArry = java.lang.reflect.Array.newInstance(data_.getClass() .getComponentType(), count); // array of same type as user passed in for (int x = 0; x < count; x++) { ((Object[]) retArry)[x] = data_[x + intIndex]; // just return values // that were set by user // with no conversion } return retArry; } else { return data_; // length 0 or null value } } // // Set the array elements from a user supplied array. // /* * Make sure the constructed value is valid and make a copy of the array * converting as needed. If this isn't copied, there could be some weird * behavior if the set array is changed before it is send to the database. */ private void setArray(Object inArray) throws SQLException { /* The array cannot be null */ if (inArray == null) { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate array is null 07006"); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"null"); return; } /* ifndef JDBC40 // If not JDBC 40, switch the type code switch (typeCode_) { case JDTypes.NCHAR: typeCode_ = Types.CHAR; break; case JDTypes.NVARCHAR: typeCode_ = Types.VARCHAR; break; case JDTypes.SQLXML: case JDTypes.NCLOB: typeCode_ = Types.CLOB; break; } endif */ /* Make sure the type is valid and matches the type of the array */ /* TODO: What if object is not array type */ Class arrayComponentClass = inArray.getClass().getComponentType(); String arrayType = arrayComponentClass.getName(); if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "setArray typeCode is " + typeCode_ + " arrayType is " + arrayType); } switch (typeCode_) { case Types.CHAR: case Types.VARCHAR: case JDTypes.NCHAR: case JDTypes.NVARCHAR: if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; String[] stringArray = new String[inStringArray.length]; System.arraycopy(inStringArray, 0, stringArray, 0, inStringArray.length); data_ = stringArray; } else if ("java.math.BigDecimal".equals(arrayType) || "java.lang.Boolean".equals(arrayType) || "java.lang.Byte".equals(arrayType) || "java.lang.Short".equals(arrayType) || "java.lang.Integer".equals(arrayType) || "java.lang.Long".equals(arrayType) || "java.lang.Float".equals(arrayType) || "java.lang.Double".equals(arrayType) || "java.sql.Date".equals(arrayType) || "java.sql.Time".equals(arrayType) || "java.sql.Timestamp".equals(arrayType) || JDUtilities.classIsInstanceOf(arrayComponentClass, "java.math.BigDecimal") || JDUtilities .classIsInstanceOf(arrayComponentClass, "java.sql.Date") || JDUtilities .classIsInstanceOf(arrayComponentClass, "java.sql.Time") || JDUtilities.classIsInstanceOf(arrayComponentClass, "java.sql.Timestamp")) { Object[] inObjectArray = (Object[]) inArray; String[] stringArray = new String[inObjectArray.length]; for (int i = 0; i < inObjectArray.length; i++) { if (inObjectArray[i] == null) { stringArray[i] = null; } else { stringArray[i] = inObjectArray[i].toString(); } } data_ = stringArray; } else if (JDUtilities.classIsInstanceOf(arrayComponentClass, "java.sql.Clob")) { Clob[] inObjectArray = (Clob[]) inArray; String[] stringArray = new String[inObjectArray.length]; for (int i = 0; i < inObjectArray.length; i++) { if (inObjectArray[i] == null) { stringArray[i] = null; } else { int length = (int) inObjectArray[i].length(); stringArray[i] = inObjectArray[i].getSubString(1, length); } } data_ = stringArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is CHAR/VARCHAR but array type is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,arrayType); } break; case Types.SMALLINT: if ("java.lang.Short".equals(arrayType)) { /* * smallints are Integers from jdbc 4.0 spec: Note: The JDBC 1.0 * specification defined the Java object mapping for the SMALLINT and * TINYINT JDBC types to be Integer. The Java language did not include * the Byte and Short data types when the JDBC 1.0 specification was * finalized. The mapping of SMALLINT and TINYINT to Integer is * maintained to preserve backwards compatibility. */ Short[] inShortArray = (Short[]) inArray; Integer[] shortArray = new Integer[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { if (inShortArray[i] == null) { shortArray[i] = null; } else { /* not null */ shortArray[i] = Integer.valueOf(inShortArray[i].shortValue()); } /* not null */ } /* for i */ data_ = shortArray; } else if ("short".equals(arrayType)) { short[] inShortArray = (short[]) inArray; Integer[] shortArray = new Integer[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { shortArray[i] = Integer.valueOf(inShortArray[i]); } /* for i */ data_ = shortArray; } else if ("java.lang.Integer".equals(arrayType)) { Integer[] inIntegerArray = (Integer[]) inArray; Integer[] shortArray = new Integer[inIntegerArray.length]; System.arraycopy(inIntegerArray, 0, shortArray, 0, inIntegerArray.length); data_ = shortArray; } else if ("int".equals(arrayType)) { int[] inIntArray = (int[]) inArray; Integer[] shortArray = new Integer[inIntArray.length]; for (int i = 0; i < inIntArray.length; i++) { shortArray[i] = Integer.valueOf(inIntArray[i]); } /* for i */ data_ = shortArray; } else if ("java.lang.Long".equals(arrayType)) { Long[] inLongArray = (Long[]) inArray; Integer[] shortArray = new Integer[inLongArray.length]; for (int i = 0; i < inLongArray.length; i++) { if (inLongArray[i] == null) { shortArray[i] = null; } else { /* not null */ long lv = inLongArray[i].longValue(); if (lv >= Short.MIN_VALUE && lv <= Short.MAX_VALUE) { shortArray[i] = Integer.valueOf((int) lv); } else { /* not in range */ if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is SMALLINT but value at index " + i + " is " + lv); } /* debug */ JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"SMALLINT("+lv+")"); } /* not in range */ } /* not null */ } /* for i */ data_ = shortArray; } else if ("java.lang.Float".equals(arrayType)) { Float[] inFloatArray = (Float[]) inArray; Integer[] shortArray = new Integer[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { if (inFloatArray[i] == null) { shortArray[i] = null; } else { /* not null */ float lv = inFloatArray[i].floatValue(); if (lv >= Short.MIN_VALUE && lv <= Short.MAX_VALUE) { shortArray[i] = Integer.valueOf((int) lv); } else { /* not in range */ if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is SMALLINT but value at index " + i + " is " + lv); } /* JDTrace.isTraceOn() */ JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"SMALLINT("+lv+")"); return; } /* not in range */ } /* not null */ } /* for i */ data_ = shortArray; } else if ("java.lang.Double".equals(arrayType)) { Double[] inDoubleArray = (Double[]) inArray; Integer[] shortArray = new Integer[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { if (inDoubleArray[i] == null) { shortArray[i] = null; } else { /* not null */ double lv = inDoubleArray[i].doubleValue(); if (lv >= Short.MIN_VALUE && lv <= Short.MAX_VALUE) { shortArray[i] = Integer.valueOf((int) lv); } else { /* not in range */ if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is SMALLINT but value at index " + i + " is " + lv); } /* JDTrace.isTraceOn() */ JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"SMALLINT("+lv+")"); return; } /* not in range */ } /* not null */ } /* for i */ data_ = shortArray; } else if ("java.math.BigDecimal".equals(arrayType)) { BigDecimal[] inBigDecimalArray = (BigDecimal[]) inArray; Integer[] shortArray = new Integer[inBigDecimalArray.length]; for (int i = 0; i < inBigDecimalArray.length; i++) { if (inBigDecimalArray[i] == null) { shortArray[i] = null; } else { /* not null */ BigInteger bi = inBigDecimalArray[i].toBigInteger(); long lv = bi.longValue(); if (lv >= Short.MIN_VALUE && lv <= Short.MAX_VALUE) { shortArray[i] = Integer.valueOf((int) lv); } else { /* not in range */ if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is SMALLINT but value at index " + i + " is " + lv); } /* debug */ JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "SMALLINT("+lv+")"); return; } /* not in range */ } /* not null */ } /* for i */ data_ = shortArray; } else if ("java.lang.Boolean".equals(arrayType)) { Boolean[] inBooleanArray = (Boolean[]) inArray; Integer[] shortArray = new Integer[inBooleanArray.length]; for (int i = 0; i < inBooleanArray.length; i++) { if (inBooleanArray[i] == null) { shortArray[i] = null; } else { /* not null */ boolean b = inBooleanArray[i].booleanValue(); if (b) { shortArray[i] = Integer.valueOf(1); } else { /* false */ shortArray[i] = Integer.valueOf(0); } /* false */ } /* not null */ } /* for i */ data_ = shortArray; } else if ("java.lang.Byte".equals(arrayType)) { Byte[] inByteArray = (Byte[]) inArray; Integer[] shortArray = new Integer[inByteArray.length]; for (int i = 0; i < inByteArray.length; i++) { if (inByteArray[i] == null) { shortArray[i] = null; } else { /* not null */ byte b = inByteArray[i].byteValue(); shortArray[i] = Integer.valueOf(b); } /* not null */ } /* for i */ data_ = shortArray; } else if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; Integer[] shortArray = new Integer[inStringArray.length]; for (int i = 0; i < inStringArray.length; i++) { if (inStringArray[i] == null) { shortArray[i] = null; } else { /* not null */ try { shortArray[i] = Integer.valueOf(Short.parseShort(inStringArray[i])); } catch (NumberFormatException nfe) { if (JDTrace.isTraceOn()) { JDTrace .logInformation( this, "DB2Array.validate 07006 type is SMALLINT but NumberFormatException thrown for string " + inStringArray[i]); } /* debug */ JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"SMALLINT("+inStringArray[i]+")"); return; } /* catch */ } /* not null */ } /* for i */ data_ = shortArray; } else { // Treat as object and try to convert. If exception then throw // data type mismatch. try { Object[] inObjectArray = (Object[]) inArray; Integer[] shortArray = new Integer[inObjectArray.length]; for (int i = 0; i < inObjectArray.length; i++) { if (inObjectArray[i] == null) { shortArray[i] = null; } else { /* not null */ try { shortArray[i] = Integer.valueOf(Short.parseShort(inObjectArray[i].toString())); } catch (NumberFormatException nfe) { if (JDTrace.isTraceOn()) { JDTrace .logInformation( this, "DB2Array.validate 07006 type is SMALLINT but NumberFormatException thrown for string " + inObjectArray[i]); } /* debug */ JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "SMALLINT("+inObjectArray[i]+")"); return; } /* catch */ } /* not null */ } /* for i */ data_ = shortArray; } catch (Exception e) { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is SMALLINT but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "SMALLINT<>"+arrayType); } } break; case Types.INTEGER: if ("java.lang.Integer".equals(arrayType)) { Integer[] inIntegerArray = (Integer[]) inArray; Integer[] integerArray = new Integer[inIntegerArray.length]; System.arraycopy(inIntegerArray, 0, integerArray, 0, inIntegerArray.length); data_ = integerArray; } else if ("int".equals(arrayType)) { int[] inIntegerArray = (int[]) inArray; Integer[] integerArray = new Integer[inIntegerArray.length]; for (int i = 0; i < inIntegerArray.length; i++) { integerArray[i] = Integer.valueOf(inIntegerArray[i]); } data_ = integerArray; } else if ("java.math.BigDecimal".equals(arrayType)) { BigDecimal[] inBigDecimalArray = (BigDecimal[]) inArray; Integer[] integerArray = new Integer[inBigDecimalArray.length]; for (int i = 0; i < inBigDecimalArray.length; i++) { if (inBigDecimalArray[i] == null) { integerArray[i] = null; } else { BigInteger bi = inBigDecimalArray[i].toBigInteger(); long lv = bi.longValue(); if (lv >= Integer.MIN_VALUE && lv <= Integer.MAX_VALUE) { integerArray[i] = Integer.valueOf((int) lv); } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is INTEGER but value at index " + i + " is " + lv); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "INTEGER("+lv+")"); return; } } } data_ = integerArray; } else if ("java.lang.Long".equals(arrayType)) { Long[] inLongArray = (Long[]) inArray; Integer[] integerArray = new Integer[inLongArray.length]; for (int i = 0; i < inLongArray.length; i++) { if (inLongArray[i] == null) { integerArray[i] = null; } else { long lv = inLongArray[i].longValue(); if (lv >= Integer.MIN_VALUE && lv <= Integer.MAX_VALUE) { integerArray[i] = Integer.valueOf((int) lv); } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is SMALLINT but value at index " + i + " is " + lv); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "SMALLINT("+lv+")"); return; } } } data_ = integerArray; } else if ("java.lang.Float".equals(arrayType)) { Float[] inFloatArray = (Float[]) inArray; Integer[] integerArray = new Integer[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { if (inFloatArray[i] == null) { integerArray[i] = null; } else { float lv = inFloatArray[i].floatValue(); if (lv >= Integer.MIN_VALUE && lv <= Integer.MAX_VALUE) { integerArray[i] = Integer.valueOf((int) lv); } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is INTEGER but value at index " + i + " is " + lv); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "INTEGER("+lv+")"); return; } } } data_ = integerArray; } else if ("java.lang.Double".equals(arrayType)) { Double[] inDoubleArray = (Double[]) inArray; Integer[] integerArray = new Integer[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { if (inDoubleArray[i] == null) { integerArray[i] = null; } else { double lv = inDoubleArray[i].doubleValue(); if (lv >= Integer.MIN_VALUE && lv <= Integer.MAX_VALUE) { integerArray[i] = Integer.valueOf((int) lv); } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is INTEGER but value at index " + i + " is " + lv); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "INTEGER("+lv+")"); return; } } } data_ = integerArray; } else if ("java.lang.Boolean".equals(arrayType)) { Boolean[] inBooleanArray = (Boolean[]) inArray; Integer[] integerArray = new Integer[inBooleanArray.length]; for (int i = 0; i < inBooleanArray.length; i++) { if (inBooleanArray[i] == null) { integerArray[i] = null; } else { boolean b = inBooleanArray[i].booleanValue(); if (b) { integerArray[i] = Integer.valueOf(1); } else { integerArray[i] = Integer.valueOf(0); } } } data_ = integerArray; } else if ("java.lang.Byte".equals(arrayType)) { Byte[] inByteArray = (Byte[]) inArray; Integer[] integerArray = new Integer[inByteArray.length]; for (int i = 0; i < inByteArray.length; i++) { if (inByteArray[i] == null) { integerArray[i] = null; } else { byte b = inByteArray[i].byteValue(); integerArray[i] = Integer.valueOf(b); } } data_ = integerArray; } else if ("java.lang.Short".equals(arrayType)) { Short[] inShortArray = (Short[]) inArray; Integer[] integerArray = new Integer[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { if (inShortArray[i] == null) { integerArray[i] = null; } else { short b = inShortArray[i].shortValue(); integerArray[i] = Integer.valueOf(b); } } data_ = integerArray; } else if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; Integer[] intArray = new Integer[inStringArray.length]; for (int i = 0; i < inStringArray.length; i++) { if (inStringArray[i] == null) { intArray[i] = null; } else { try { intArray[i] = Integer.valueOf(inStringArray[i]); } catch (NumberFormatException nfe) { if (JDTrace.isTraceOn()) { JDTrace .logInformation( this, "DB2Array.validate 07006 type is INTEGER but NumberFormatException thrown for string " + inStringArray[i]); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "INTEGER("+inStringArray[i]+")"); return; } } } data_ = intArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is INTEGER but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "INTEGER<>"+arrayType); } break; case Types.BIGINT: if ("java.lang.Long".equals(arrayType)) { Long[] inLongArray = (Long[]) inArray; Long[] longArray = new Long[inLongArray.length]; System.arraycopy(inLongArray, 0, longArray, 0, inLongArray.length); data_ = longArray; } else if ("long".equals(arrayType)) { long[] inLongArray = (long[]) inArray; Long[] longArray = new Long[inLongArray.length]; for (int i = 0; i < inLongArray.length; i++) { longArray[i] = Long.valueOf(inLongArray[i]); } data_ = longArray; } else if ("java.math.BigDecimal".equals(arrayType)) { BigDecimal[] inBigDecimalArray = (BigDecimal[]) inArray; Long[] longArray = new Long[inBigDecimalArray.length]; for (int i = 0; i < inBigDecimalArray.length; i++) { if (inBigDecimalArray[i] == null) { longArray[i] = null; } else { BigInteger bi = inBigDecimalArray[i].toBigInteger(); long lv = bi.longValue(); if (lv >= Long.MIN_VALUE && lv <= Long.MAX_VALUE) { longArray[i] = Long.valueOf((int) lv); } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is BIGINT but value at index " + i + " is " + lv); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "BIGINT("+lv+")"); return; } } } data_ = longArray; } else if ("java.lang.Boolean".equals(arrayType)) { Boolean[] inBooleanArray = (Boolean[]) inArray; Long[] longArray = new Long[inBooleanArray.length]; for (int i = 0; i < inBooleanArray.length; i++) { if (inBooleanArray[i] == null) { longArray[i] = null; } else { boolean b = inBooleanArray[i].booleanValue(); if (b) { longArray[i] = Long.valueOf(1); } else { longArray[i] = Long.valueOf(0); } } } data_ = longArray; } else if ("java.lang.Float".equals(arrayType)) { Float[] inFloatArray = (Float[]) inArray; Long[] longArray = new Long[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { if (inFloatArray[i] == null) { longArray[i] = null; } else { float lv = inFloatArray[i].floatValue(); if (lv >= Long.MIN_VALUE && lv <= Long.MAX_VALUE) { longArray[i] = Long.valueOf((int) lv); } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is LONG but value at index " + i + " is " + lv); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "BIGINT("+lv+")"); return; } } } data_ = longArray; } else if ("java.lang.Double".equals(arrayType)) { Double[] inDoubleArray = (Double[]) inArray; Long[] longArray = new Long[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { if (inDoubleArray[i] == null) { longArray[i] = null; } else { double lv = inDoubleArray[i].doubleValue(); if (lv >= Long.MIN_VALUE && lv <= Long.MAX_VALUE) { longArray[i] = Long.valueOf((int) lv); } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is BIGINT but value at index " + i + " is " + lv); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "BIGINT("+lv+")"); return; } } } data_ = longArray; } else if ("java.lang.Byte".equals(arrayType)) { Byte[] inByteArray = (Byte[]) inArray; Long[] longArray = new Long[inByteArray.length]; for (int i = 0; i < inByteArray.length; i++) { if (inByteArray[i] == null) { longArray[i] = null; } else { byte b = inByteArray[i].byteValue(); longArray[i] = Long.valueOf(b); } } data_ = longArray; } else if ("java.lang.Short".equals(arrayType)) { Short[] inShortArray = (Short[]) inArray; Long[] longArray = new Long[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { if (inShortArray[i] == null) { longArray[i] = null; } else { short b = inShortArray[i].shortValue(); longArray[i] = Long.valueOf(b); } } data_ = longArray; } else if ("java.lang.Integer".equals(arrayType)) { Integer[] inIntegerArray = (Integer[]) inArray; Long[] longArray = new Long[inIntegerArray.length]; for (int i = 0; i < inIntegerArray.length; i++) { if (inIntegerArray[i] == null) { longArray[i] = null; } else { int b = inIntegerArray[i].intValue(); longArray[i] = Long.valueOf(b); } } data_ = longArray; } else if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; Long[] longArray = new Long[inStringArray.length]; for (int i = 0; i < inStringArray.length; i++) { if (inStringArray[i] == null) { longArray[i] = null; } else { try { longArray[i] = Long.valueOf(inStringArray[i]); } catch (NumberFormatException nfe) { if (JDTrace.isTraceOn()) { JDTrace .logInformation( this, "DB2Array.validate 07006 type is BIGINT but NumberFormatException thrown for string " + inStringArray[i]); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "BIGINT("+inStringArray[i]+")"); return; } } } data_ = longArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is BIGINT but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "BIGINT<>"+arrayType); return; } break; case Types.REAL: if ("java.lang.Float".equals(arrayType)) { Float[] inFloatArray = (Float[]) inArray; Float[] floatArray = new Float[inFloatArray.length]; System.arraycopy(inFloatArray, 0, floatArray, 0, inFloatArray.length); data_ = floatArray; } else if ("float".equals(arrayType)) { float[] inFloatArray = (float[]) inArray; Float[] floatArray = new Float[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { floatArray[i] = Float.valueOf(inFloatArray[i]); } data_ = floatArray; } else if ("java.lang.Short".equals(arrayType)) { Short[] inShortArray = (Short[]) inArray; Float[] floatArray = new Float[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { if (inShortArray[i] == null) { floatArray[i] = null; } else { floatArray[i] = Float.valueOf(inShortArray[i].shortValue()); } } data_ = floatArray; } else if ("short".equals(arrayType)) { short[] inShortArray = (short[]) inArray; Float[] floatArray = new Float[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { floatArray[i] = Float.valueOf(inShortArray[i]); } /* for i */ data_ = floatArray; } else if ("java.lang.Integer".equals(arrayType)) { Integer[] inIntegerArray = (Integer[]) inArray; Float[] floatArray = new Float[inIntegerArray.length]; for (int i = 0; i < inIntegerArray.length; i++) { if (inIntegerArray[i] == null) { floatArray[i] = null; } else { /* not null */ floatArray[i] = Float.valueOf(inIntegerArray[i].floatValue()); } /* not null */ } /* for i */ data_ = floatArray; } else if ("int".equals(arrayType)) { int[] inIntArray = (int[]) inArray; Float[] floatArray = new Float[inIntArray.length]; for (int i = 0; i < inIntArray.length; i++) { floatArray[i] = Float.valueOf(inIntArray[i]); } /* for */ data_ = floatArray; } else if ("java.lang.Long".equals(arrayType)) { Long[] inLongArray = (Long[]) inArray; Float[] floatArray = new Float[inLongArray.length]; for (int i = 0; i < inLongArray.length; i++) { if (inLongArray[i] == null) { floatArray[i] = null; } else { /* not null */ long lv = inLongArray[i].longValue(); if (lv >= - Float.MAX_VALUE && lv <= Float.MAX_VALUE) { floatArray[i] = Float.valueOf(lv); } else { /* in range */ if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is REAL but value at index " + i + " is " + lv); } /* debug */ JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"REAL("+lv+")"); return; } /* in range */ } /* not null */ } /* for */ data_ = floatArray; } else if ("java.lang.Float".equals(arrayType)) { Float[] inFloatArray = (Float[]) inArray; Float[] floatArray = new Float[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { if (inFloatArray[i] == null) { floatArray[i] = null; } else { /* not null */ float lv = inFloatArray[i].floatValue(); if (lv >= - Float.MAX_VALUE && lv <= Float.MAX_VALUE) { floatArray[i] = Float.valueOf(lv); } else { /* in range */ if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is REAL but value at index " + i + " is " + lv); } /* debug */ JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"REAL("+lv+")"); return; } /* in range */ } /* not null */ } /* for */ data_ = floatArray; } else if ("java.lang.Double".equals(arrayType)) { Double[] inDoubleArray = (Double[]) inArray; Float[] floatArray = new Float[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { if (inDoubleArray[i] == null) { floatArray[i] = null; } else { double lv = inDoubleArray[i].doubleValue(); if (lv >= - Float.MAX_VALUE && lv <= Float.MAX_VALUE) { floatArray[i] = Float.valueOf((float) lv); } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is REAL but value at index " + i + " is " + lv); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"REAL("+lv+")"); return; } } } data_ = floatArray; } else if ("java.math.BigDecimal".equals(arrayType)) { BigDecimal[] inBigDecimalArray = (BigDecimal[]) inArray; Float[] floatArray = new Float[inBigDecimalArray.length]; for (int i = 0; i < inBigDecimalArray.length; i++) { if (inBigDecimalArray[i] == null) { floatArray[i] = null; } else { float f = inBigDecimalArray[i].floatValue(); if (f == Float.NEGATIVE_INFINITY || f == Float.POSITIVE_INFINITY) { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is REAL but value at index " + i + " is " + f); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"REAL("+f+")"); return; } else { floatArray[i] = Float.valueOf(f); } } } data_ = floatArray; } else if ("java.lang.Boolean".equals(arrayType)) { Boolean[] inBooleanArray = (Boolean[]) inArray; Float[] floatArray = new Float[inBooleanArray.length]; for (int i = 0; i < inBooleanArray.length; i++) { if (inBooleanArray[i] == null) { floatArray[i] = null; } else { boolean b = inBooleanArray[i].booleanValue(); if (b) { floatArray[i] = Float.valueOf(1); } else { floatArray[i] = Float.valueOf(0); } } } data_ = floatArray; } else if ("java.lang.Byte".equals(arrayType)) { Byte[] inByteArray = (Byte[]) inArray; Float[] floatArray = new Float[inByteArray.length]; for (int i = 0; i < inByteArray.length; i++) { if (inByteArray[i] == null) { floatArray[i] = null; } else { byte b = inByteArray[i].byteValue(); floatArray[i] = Float.valueOf(b); } } data_ = floatArray; } else if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; Float[] floatArray = new Float[inStringArray.length]; for (int i = 0; i < inStringArray.length; i++) { if (inStringArray[i] == null) { floatArray[i] = null; } else { try { floatArray[i] = Float.valueOf(inStringArray[i]); } catch (NumberFormatException nfe) { if (JDTrace.isTraceOn()) { JDTrace .logInformation( this, "DB2Array.validate 07006 type is REAL but NumberFormatException thrown for string " + inStringArray[i]); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"REAL("+inStringArray[i]+")"); return; } } } data_ = floatArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is REAL but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"REAL<>"+arrayType); } break; case Types.FLOAT: if ("java.lang.Double".equals(arrayType)) { Double[] inDoubleArray = (Double[]) inArray; Double[] doubleArray = new Double[inDoubleArray.length]; System.arraycopy(inDoubleArray, 0, doubleArray, 0, inDoubleArray.length); data_ = doubleArray; } else if ("double".equals(arrayType)) { double[] inDoubleArray = (double[]) inArray; Double[] doubleArray = new Double[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { doubleArray[i] = Double.valueOf(inDoubleArray[i]); } data_ = doubleArray; } else if ("java.lang.Float".equals(arrayType)) { /* Types.FLOAT should always map to Double */ Float[] inFloatArray = (Float[]) inArray; Double[] floatArray = new Double[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { if (inFloatArray[i] == null) { floatArray[i] = null; } else { floatArray[i] = Double.valueOf(inFloatArray[i].doubleValue()); } } data_ = floatArray; } else if ("float".equals(arrayType)) { float[] inFloatArray = (float[]) inArray; Double[] floatArray = new Double[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { floatArray[i] = Double.valueOf(inFloatArray[i]); } data_ = floatArray; } else if ("java.lang.Short".equals(arrayType)) { Short[] inShortArray = (Short[]) inArray; Double[] doubleArray = new Double[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { if (inShortArray[i] == null) { doubleArray[i] = null; } else { doubleArray[i] = Double.valueOf(inShortArray[i].shortValue()); } } data_ = doubleArray; } else if ("short".equals(arrayType)) { short[] inShortArray = (short[]) inArray; Double[] doubleArray = new Double[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { doubleArray[i] = Double.valueOf(inShortArray[i]); } data_ = doubleArray; } else if ("java.lang.Integer".equals(arrayType)) { Integer[] inIntegerArray = (Integer[]) inArray; Double[] doubleArray = new Double[inIntegerArray.length]; for (int i = 0; i < inIntegerArray.length; i++) { if (inIntegerArray[i] == null) { doubleArray[i] = null; } else { doubleArray[i] = Double.valueOf(inIntegerArray[i].doubleValue()); } } data_ = doubleArray; } else if ("int".equals(arrayType)) { int[] inIntArray = (int[]) inArray; Double[] doubleArray = new Double[inIntArray.length]; for (int i = 0; i < inIntArray.length; i++) { doubleArray[i] = Double.valueOf(inIntArray[i]); } data_ = doubleArray; } else if ("java.lang.Long".equals(arrayType)) { Long[] inLongArray = (Long[]) inArray; Double[] doubleArray = new Double[inLongArray.length]; for (int i = 0; i < inLongArray.length; i++) { if (inLongArray[i] == null) { doubleArray[i] = null; } else { long lv = inLongArray[i].longValue(); doubleArray[i] = Double.valueOf(lv); } } data_ = doubleArray; } else if ("java.math.BigDecimal".equals(arrayType)) { BigDecimal[] inBigDecimalArray = (BigDecimal[]) inArray; Double[] doubleArray = new Double[inBigDecimalArray.length]; for (int i = 0; i < inBigDecimalArray.length; i++) { if (inBigDecimalArray[i] == null) { doubleArray[i] = null; } else { double f = inBigDecimalArray[i].doubleValue(); if (f == Double.NEGATIVE_INFINITY || f == Double.POSITIVE_INFINITY) { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is Double but value at index " + i + " is " + f); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DOUBLE("+f+")"); return; } else { doubleArray[i] = Double.valueOf(f); } } } data_ = doubleArray; } else if ("java.lang.Boolean".equals(arrayType)) { Boolean[] inBooleanArray = (Boolean[]) inArray; Double[] doubleArray = new Double[inBooleanArray.length]; for (int i = 0; i < inBooleanArray.length; i++) { if (inBooleanArray[i] == null) { doubleArray[i] = null; } else { boolean b = inBooleanArray[i].booleanValue(); if (b) { doubleArray[i] = Double.valueOf(1); } else { doubleArray[i] = Double.valueOf(0); } } } data_ = doubleArray; } else if ("java.lang.Byte".equals(arrayType)) { Byte[] inByteArray = (Byte[]) inArray; Double[] doubleArray = new Double[inByteArray.length]; for (int i = 0; i < inByteArray.length; i++) { if (inByteArray[i] == null) { doubleArray[i] = null; } else { byte b = inByteArray[i].byteValue(); doubleArray[i] = Double.valueOf(b); } } data_ = doubleArray; } else if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; Double[] doubleArray = new Double[inStringArray.length]; for (int i = 0; i < inStringArray.length; i++) { if (inStringArray[i] == null) { doubleArray[i] = null; } else { try { doubleArray[i] = Double.valueOf(inStringArray[i]); } catch (NumberFormatException nfe) { if (JDTrace.isTraceOn()) { JDTrace .logInformation( this, "DB2Array.validate 07006 type is Double but NumberFormatException thrown for string " + inStringArray[i]); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DOUBLE("+inStringArray[i]+")"); return; } } } data_ = doubleArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is DOUBLE but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DOUBLE<>"+arrayType); } break; case Types.DOUBLE: if ("java.lang.Double".equals(arrayType)) { Double[] inDoubleArray = (Double[]) inArray; Double[] doubleArray = new Double[inDoubleArray.length]; System.arraycopy(inDoubleArray, 0, doubleArray, 0, inDoubleArray.length); data_ = doubleArray; } else if ("double".equals(arrayType)) { double[] inDoubleArray = (double[]) inArray; Double[] doubleArray = new Double[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { doubleArray[i] = Double.valueOf(inDoubleArray[i]); } data_ = doubleArray; } else if ("java.lang.Float".equals(arrayType)) { /* Types.FLOAT should always map to Double */ Float[] inFloatArray = (Float[]) inArray; Double[] floatArray = new Double[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { if (inFloatArray[i] == null) { floatArray[i] = null; } else { floatArray[i] = Double.valueOf(inFloatArray[i].doubleValue()); } } data_ = floatArray; } else if ("float".equals(arrayType)) { float[] inFloatArray = (float[]) inArray; Double[] floatArray = new Double[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { floatArray[i] = Double.valueOf(inFloatArray[i]); } data_ = floatArray; } else if ("java.lang.Short".equals(arrayType)) { Short[] inShortArray = (Short[]) inArray; Double[] doubleArray = new Double[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { if (inShortArray[i] == null) { doubleArray[i] = null; } else { doubleArray[i] = Double.valueOf(inShortArray[i].shortValue()); } } data_ = doubleArray; } else if ("short".equals(arrayType)) { short[] inShortArray = (short[]) inArray; Double[] doubleArray = new Double[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { doubleArray[i] = Double.valueOf(inShortArray[i]); } data_ = doubleArray; } else if ("java.lang.Integer".equals(arrayType)) { Integer[] inIntegerArray = (Integer[]) inArray; Double[] doubleArray = new Double[inIntegerArray.length]; for (int i = 0; i < inIntegerArray.length; i++) { if (inIntegerArray[i] == null) { doubleArray[i] = null; } else { doubleArray[i] = Double.valueOf(inIntegerArray[i].doubleValue()); } } data_ = doubleArray; } else if ("int".equals(arrayType)) { int[] inIntArray = (int[]) inArray; Double[] doubleArray = new Double[inIntArray.length]; for (int i = 0; i < inIntArray.length; i++) { doubleArray[i] = Double.valueOf(inIntArray[i]); } data_ = doubleArray; } else if ("java.lang.Long".equals(arrayType)) { Long[] inLongArray = (Long[]) inArray; Double[] doubleArray = new Double[inLongArray.length]; for (int i = 0; i < inLongArray.length; i++) { if (inLongArray[i] == null) { doubleArray[i] = null; } else { long lv = inLongArray[i].longValue(); doubleArray[i] = Double.valueOf(lv); } } data_ = doubleArray; } else if ("java.math.BigDecimal".equals(arrayType)) { BigDecimal[] inBigDecimalArray = (BigDecimal[]) inArray; Double[] doubleArray = new Double[inBigDecimalArray.length]; for (int i = 0; i < inBigDecimalArray.length; i++) { if (inBigDecimalArray[i] == null) { doubleArray[i] = null; } else { double f = inBigDecimalArray[i].doubleValue(); if (f == Double.NEGATIVE_INFINITY || f == Double.POSITIVE_INFINITY) { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.setArray 07006 type is Double but value at index " + i + " is " + f); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DOUBLE("+f+")"); return; } else { doubleArray[i] = Double.valueOf(f); } } } data_ = doubleArray; } else if ("java.lang.Boolean".equals(arrayType)) { Boolean[] inBooleanArray = (Boolean[]) inArray; Double[] doubleArray = new Double[inBooleanArray.length]; for (int i = 0; i < inBooleanArray.length; i++) { if (inBooleanArray[i] == null) { doubleArray[i] = null; } else { boolean b = inBooleanArray[i].booleanValue(); if (b) { doubleArray[i] = Double.valueOf(1); } else { doubleArray[i] = Double.valueOf(0); } } } data_ = doubleArray; } else if ("java.lang.Byte".equals(arrayType)) { Byte[] inByteArray = (Byte[]) inArray; Double[] doubleArray = new Double[inByteArray.length]; for (int i = 0; i < inByteArray.length; i++) { if (inByteArray[i] == null) { doubleArray[i] = null; } else { byte b = inByteArray[i].byteValue(); doubleArray[i] = Double.valueOf(b); } } data_ = doubleArray; } else if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; Double[] doubleArray = new Double[inStringArray.length]; for (int i = 0; i < inStringArray.length; i++) { if (inStringArray[i] == null) { doubleArray[i] = null; } else { try { doubleArray[i] = Double.valueOf(inStringArray[i]); } catch (NumberFormatException nfe) { if (JDTrace.isTraceOn()) { JDTrace .logInformation( this, "DB2Array.validate 07006 type is Double but NumberFormatException thrown for string " + inStringArray[i]); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DOUBLE("+inStringArray[i]+")"); return; } } } data_ = doubleArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is DOUBLE/FLOAT but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DOUBLE<>"+arrayType); } break; case Types.DECIMAL: case Types.NUMERIC: case JDTypes.SQL_DECFLOAT: if (JDUtilities.classIsInstanceOf(arrayComponentClass, "java.math.BigDecimal")) { BigDecimal[] inBdArray = (BigDecimal[]) inArray; BigDecimal[] bdArray = new BigDecimal[inBdArray.length]; System.arraycopy(inBdArray, 0, bdArray, 0, inBdArray.length); data_ = bdArray; } else if ("java.lang.Double".equals(arrayType)) { Double[] inDoubleArray = (Double[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { if (inDoubleArray[i] == null) { bigDecimalArray[i] = null; } else { bigDecimalArray[i] = new BigDecimal(inDoubleArray[i].doubleValue()); } } data_ = bigDecimalArray; } else if ("double".equals(arrayType)) { double[] inDoubleArray = (double[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { bigDecimalArray[i] = new BigDecimal(inDoubleArray[i]); } data_ = bigDecimalArray; } else if ("java.lang.Float".equals(arrayType)) { /* Types.FLOAT should always map to Double */ Float[] inFloatArray = (Float[]) inArray; BigDecimal[] floatArray = new BigDecimal[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { if (inFloatArray[i] == null) { floatArray[i] = null; } else { floatArray[i] = new BigDecimal(inFloatArray[i].doubleValue()); } } data_ = floatArray; } else if ("float".equals(arrayType)) { float[] inFloatArray = (float[]) inArray; BigDecimal[] floatArray = new BigDecimal[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { floatArray[i] = new BigDecimal(inFloatArray[i]); } data_ = floatArray; } else if ("java.lang.Short".equals(arrayType)) { Short[] inShortArray = (Short[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { if (inShortArray[i] == null) { bigDecimalArray[i] = null; } else { bigDecimalArray[i] = new BigDecimal(inShortArray[i].doubleValue()); } } data_ = bigDecimalArray; } else if ("short".equals(arrayType)) { short[] inShortArray = (short[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { bigDecimalArray[i] = new BigDecimal((double) inShortArray[i]); } data_ = bigDecimalArray; } else if ("java.lang.Integer".equals(arrayType)) { Integer[] inIntegerArray = (Integer[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inIntegerArray.length]; for (int i = 0; i < inIntegerArray.length; i++) { if (inIntegerArray[i] == null) { bigDecimalArray[i] = null; } else { bigDecimalArray[i] = new BigDecimal(inIntegerArray[i].doubleValue()); } } data_ = bigDecimalArray; } else if ("int".equals(arrayType)) { int[] inIntArray = (int[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inIntArray.length]; for (int i = 0; i < inIntArray.length; i++) { bigDecimalArray[i] = new BigDecimal((double) inIntArray[i]); } data_ = bigDecimalArray; } else if ("java.lang.Long".equals(arrayType)) { Long[] inLongArray = (Long[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inLongArray.length]; for (int i = 0; i < inLongArray.length; i++) { if (inLongArray[i] == null) { bigDecimalArray[i] = null; } else { long lv = inLongArray[i].longValue(); bigDecimalArray[i] = new BigDecimal((double) lv); } } data_ = bigDecimalArray; } else if ("java.lang.Boolean".equals(arrayType)) { Boolean[] inBooleanArray = (Boolean[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inBooleanArray.length]; for (int i = 0; i < inBooleanArray.length; i++) { if (inBooleanArray[i] == null) { bigDecimalArray[i] = null; } else { boolean b = inBooleanArray[i].booleanValue(); if (b) { bigDecimalArray[i] = new BigDecimal(1.0); } else { bigDecimalArray[i] = new BigDecimal(0.0); } } } data_ = bigDecimalArray; } else if ("java.lang.Byte".equals(arrayType)) { Byte[] inByteArray = (Byte[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inByteArray.length]; for (int i = 0; i < inByteArray.length; i++) { if (inByteArray[i] == null) { bigDecimalArray[i] = null; } else { byte b = inByteArray[i].byteValue(); bigDecimalArray[i] = new BigDecimal((double) b); } } data_ = bigDecimalArray; } else if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; BigDecimal[] bigDecimalArray = new BigDecimal[inStringArray.length]; for (int i = 0; i < inStringArray.length; i++) { if (inStringArray[i] == null) { bigDecimalArray[i] = null; } else { try { bigDecimalArray[i] = new BigDecimal(inStringArray[i]); } catch (NumberFormatException nfe) { if (JDTrace.isTraceOn()) { JDTrace .logInformation( this, "DB2Array.validate 07006 type is DECIMAL/NUMERIC/DECFLOAT but NumberFormatException thrown for string " + inStringArray[i]); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DECIMAL["+i+"]("+inStringArray[i]+")"); return; } } } data_ = bigDecimalArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is DECIMAL/NUMERIC/DECFLOAT but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DECIMAL<>"+arrayType); return; } break; case Types.BINARY: case Types.VARBINARY: if ("[B".equals(arrayType)) { byte[][] inByteArray = (byte[][]) inArray; byte[][] byteArray = new byte[inByteArray.length][]; System.arraycopy(inByteArray, 0, byteArray, 0, inByteArray.length); data_ = byteArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is BINARY/VARBINARY but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"BINARY<>"+arrayType); } break; case Types.BLOB: if (JDUtilities.classIsInstanceOf(arrayComponentClass, "java.sql.Blob")) { Blob[] inBlobArray = (Blob[]) inArray; Blob[] blobArray = new Blob[inBlobArray.length]; System.arraycopy(inBlobArray, 0, blobArray, 0, inBlobArray.length); data_ = blobArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is BLOB but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"BLOB<>"+arrayType); } break; case Types.CLOB: case 2011: /* Types.NCLOB */ if (JDUtilities.classIsInstanceOf(arrayComponentClass, "java.sql.Clob")) { Clob[] inClobArray = (Clob[]) inArray; Clob[] clobArray = new Clob[inClobArray.length]; System.arraycopy(inClobArray, 0, clobArray, 0, inClobArray.length); data_ = clobArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is CLOB but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "CLOB<>"+arrayType); } break; case Types.DATE: if (JDUtilities.classIsInstanceOf(arrayComponentClass, "java.sql.Date")) { Date[] inDateArray = (Date[]) inArray; Date[] dateArray = new Date[inDateArray.length]; System.arraycopy(inDateArray, 0, dateArray, 0, inDateArray.length); data_ = dateArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is DATE but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"DATE<>"+arrayType); } break; /* ifdef JDBC40 */ case 2009: // Types.SQLXML { boolean allValid = true; String subArrayType = ""; Object[] inSQLXMLArray = (Object[]) inArray; SQLXML[] SQLXMLArray = new SQLXML[inSQLXMLArray.length]; for (int i = 0; allValid && i < inSQLXMLArray.length; i++) { if ( inSQLXMLArray[i] == null) { SQLXMLArray[i] = null; } else { if ( inSQLXMLArray[i] instanceof SQLXML ) { SQLXMLArray[i] = (SQLXML) inSQLXMLArray[i]; } else { subArrayType = inSQLXMLArray[i].getClass().getName(); allValid = false; } } } if (allValid) { data_ =SQLXMLArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is SQLXML but array types is " +arrayType+" subArrayType = "+subArrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH); } } break; /* endif */ case Types.TIME: if (JDUtilities.classIsInstanceOf(arrayComponentClass, "java.sql.Time")) { Time[] inTimeArray = (Time[]) inArray; Time[] timeArray = new Time[inTimeArray.length]; System.arraycopy(inTimeArray, 0, timeArray, 0, inTimeArray.length); data_ = timeArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is TIME but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "TIME<>"+arrayType); } break; case Types.TIMESTAMP: if (JDUtilities.classIsInstanceOf(arrayComponentClass, "java.sql.Timestamp")) { Timestamp[] inTimestampArray = (Timestamp[]) inArray; Timestamp[] timestampArray = new Timestamp[inTimestampArray.length]; System.arraycopy(inTimestampArray, 0, timestampArray, 0, inTimestampArray.length); data_ = timestampArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is TIMESTAMP but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,"TIMESTAMP<>"+arrayType); } break; case Types.BOOLEAN: if ("java.lang.Boolean".equals(arrayType)) { Boolean[] inBooleanArray = (Boolean[]) inArray; Boolean[] booleanArray = new Boolean[inBooleanArray.length]; System.arraycopy(inBooleanArray, 0, booleanArray, 0, inBooleanArray.length); data_ = booleanArray; } else if ("boolean".equals(arrayType)) { boolean[] inBooleanArray = (boolean[]) inArray; Boolean[] booleanArray = new Boolean[inBooleanArray.length]; for (int i = 0; i < inBooleanArray.length; i++) { booleanArray[i] = Boolean.valueOf(inBooleanArray[i]); } data_ = booleanArray; } else if ("java.lang.Integer".equals(arrayType)) { Integer[] inIntegerArray = (Integer[]) inArray; Boolean[] booleanArray = new Boolean[inIntegerArray.length]; for (int i = 0; i < inIntegerArray.length; i++) { booleanArray[i] = SQLBoolean.getBooleanObject(this, inIntegerArray[i]); } data_ = booleanArray; } else if ("int".equals(arrayType)) { int[] inIntegerArray = (int[]) inArray; Boolean[] booleanArray = new Boolean[inIntegerArray.length]; for (int i = 0; i < inIntegerArray.length; i++) { booleanArray[i] = Boolean.valueOf(SQLBoolean.getBoolean(this, inIntegerArray[i])); } data_ = booleanArray; } else if ("java.math.BigDecimal".equals(arrayType)) { BigDecimal[] inBigDecimalArray = (BigDecimal[]) inArray; Boolean[] booleanArray = new Boolean[inBigDecimalArray.length]; for (int i = 0; i < inBigDecimalArray.length; i++) { booleanArray[i] = SQLBoolean.getBooleanObject(this, inBigDecimalArray[i]); } data_ = booleanArray; } else if ("java.lang.Long".equals(arrayType)) { Long[] inLongArray = (Long[]) inArray; Boolean[] booleanArray = new Boolean[inLongArray.length]; for (int i = 0; i < inLongArray.length; i++) { booleanArray[i] = SQLBoolean.getBooleanObject(this, inLongArray[i]); } data_ = booleanArray; } else if ("java.lang.Float".equals(arrayType)) { Float[] inFloatArray = (Float[]) inArray; Boolean[] booleanArray = new Boolean[inFloatArray.length]; for (int i = 0; i < inFloatArray.length; i++) { booleanArray[i] = SQLBoolean.getBooleanObject(this, inFloatArray[i]); } data_ = booleanArray; } else if ("java.lang.Double".equals(arrayType)) { Double[] inDoubleArray = (Double[]) inArray; Boolean[] booleanArray = new Boolean[inDoubleArray.length]; for (int i = 0; i < inDoubleArray.length; i++) { booleanArray[i] = SQLBoolean.getBooleanObject(this, inDoubleArray[i]); } data_ = booleanArray; } else if ("java.lang.Byte".equals(arrayType)) { Byte[] inByteArray = (Byte[]) inArray; Boolean[] booleanArray = new Boolean[inByteArray.length]; for (int i = 0; i < inByteArray.length; i++) { booleanArray[i] = SQLBoolean.getBooleanObject(this, inByteArray[i]); } data_ = booleanArray; } else if ("java.lang.Short".equals(arrayType)) { Short[] inShortArray = (Short[]) inArray; Boolean[] booleanArray = new Boolean[inShortArray.length]; for (int i = 0; i < inShortArray.length; i++) { booleanArray[i] = SQLBoolean.getBooleanObject(this, inShortArray[i]); } data_ = booleanArray; } else if ("java.lang.String".equals(arrayType)) { String[] inStringArray = (String[]) inArray; Boolean[] booleanArray = new Boolean[inStringArray.length]; for (int i = 0; i < inStringArray.length; i++) { booleanArray[i] = SQLBoolean.getBooleanObject(this, inStringArray[i]); } data_ = booleanArray; } else { if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 type is INTEGER but array types is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH, "INTEGER<>"+arrayType); } break; /* Array of array not supported */ /* case Types.ROWID : */ case Types.NULL: case Types.DISTINCT: case Types.STRUCT: case Types.JAVA_OBJECT: /* case Types.LONGNVARCHAR : */ case Types.LONGVARBINARY: case Types.LONGVARCHAR: case Types.DATALINK: case Types.OTHER: case Types.REF: case Types.TINYINT: case Types.BIT: case Types.ARRAY: default: if (JDTrace.isTraceOn()) { JDTrace.logInformation(this, "DB2Array.validate 07006 invalid type " + typeCode_ + " array type is " + arrayType); } JDError.throwSQLException(JDError.EXC_DATA_TYPE_MISMATCH,typeCode_+"<>"+arrayType); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy