src.com.ibm.as400.access.JDSimpleDelimitedFieldMap Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
//
//JTOpen (IBM Toolbox for Java - OSS version)
//
//Filename: JDSimpleDelimitedFieldMap.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-2001 International Business Machines Corporation and
//others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
import java.sql.SQLException;
/**
*
* A class that defines how the client sees the data for a mapped field, i.e., a
* field that simply gets copied from an actual field in the row data, as is with
* start and end delimiters trimmed. This is needed because the db returns
* schema, pk, and fk names with delimiter chars.
* Note that this FieldMap is designed only for strings.
* Note that the field index may be different than the field that this is
* representing.
*
*
* For example, a field comes as the 3rd column, but we need to map it to the
* 5th column.
*/
class JDSimpleDelimitedFieldMap implements JDFieldMap {
static final String copyright = "Copyright (C) 1997-2006 International Business Machines Corporation and others.";
private int fromIndex_;
JDSimpleDelimitedFieldMap(int fromIndex) {
fromIndex_ = fromIndex;
}
public Object getValue(JDRow row) throws SQLException {
SQLChar charData = (SQLChar)row.getSQLData(fromIndex_);
String value = charData.getString().trim();
value = JDUtilities.stripOutDoubleEmbededQuotes(value);
return value;
}
/**
* Indicates if the value was a data mapping error.
*/
public boolean isDataMappingError(JDRow row) throws SQLException {
return row.isDataMappingError(fromIndex_);
}
public boolean isNull(JDRow row) throws SQLException {
return row.isNull(fromIndex_);
}
}