org.firebirdsql.jdbc.field.FBStringField Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of jaybird-jdk17 Show documentation
Show all versions of jaybird-jdk17 Show documentation
JDBC Driver for the Firebird RDBMS
/*
* $Id: FBStringField.java 58482 2013-08-10 14:37:31Z mrotteveel $
*
* Firebird Open Source J2ee connector - jdbc driver
*
* Distributable under LGPL license.
* You may obtain a copy of the License at http://www.gnu.org/copyleft/lgpl.html
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* LGPL License for more details.
*
* This file was created by members of the firebird development team.
* All individual contributions remain the Copyright (C) of those
* individuals. Contributors to this file are either listed here or
* can be obtained from a CVS history command.
*
* All rights reserved.
*/
package org.firebirdsql.jdbc.field;
import java.math.BigDecimal;
import java.util.Calendar;
import java.sql.Timestamp;
import java.sql.Date;
import java.sql.Time;
import java.sql.SQLException;
import java.sql.DataTruncation;
import java.io.InputStream;
import java.io.Reader;
import java.io.StringWriter;
import java.io.IOException;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import org.firebirdsql.encodings.EncodingFactory;
import org.firebirdsql.gds.XSQLVAR;
import org.firebirdsql.gds.impl.GDSHelper;
/**
* Describe class FBStringField
here.
*
* @author Roman Rokytskyy
* @author David Jencks
* @author Mark Rotteveel
* @version 1.0
*
* @todo implement data handling code
*
* @todo implement correct exception throwing in all setXXX methods that use
* setString(String), currently it will raise an exception with string conversion
* error message, instead it should complain about error coresponding to the XXX.
*
* @todo think about the right setBoolean and getBoolean (currently it is "Y"
* and "N", or "TRUE" and "FALSE").
*
* TODO check if the setBinaryStream(null) is allowed by specs.
*/
public class FBStringField extends FBField {
static final String SHORT_TRUE = "Y";
static final String SHORT_FALSE = "N";
static final String LONG_TRUE = "true";
static final String LONG_FALSE = "false";
static final String SHORT_TRUE_2 = "T";
static final String SHORT_TRUE_3 = "1";
protected int possibleCharLength;
protected int bytesPerCharacter;
FBStringField(XSQLVAR field, FieldDataProvider dataProvider, int requiredType) throws SQLException {
super(field, dataProvider, requiredType);
bytesPerCharacter = 1;
possibleCharLength = field.sqllen / bytesPerCharacter;
}
/**
* Set connection for this field. This method estimates character
* length and bytes per chracter.
*/
public void setConnection(GDSHelper gdsHelper) {
super.setConnection(gdsHelper);
bytesPerCharacter = EncodingFactory.getIscEncodingSize(iscEncoding);
possibleCharLength = field.sqllen / bytesPerCharacter;
}
//----- Math code
public byte getByte() throws SQLException {
if (getFieldData()==null) return BYTE_NULL_VALUE;
try {
return Byte.parseByte(getString().trim());
} catch (NumberFormatException nfex) {
throw (SQLException) createException(
BYTE_CONVERSION_ERROR+" "+getString().trim()).fillInStackTrace();
}
}
public short getShort() throws SQLException {
if (getFieldData()==null) return SHORT_NULL_VALUE;
try {
return Short.parseShort(getString().trim());
} catch (NumberFormatException nfex) {
throw (SQLException) createException(
SHORT_CONVERSION_ERROR+" "+getString().trim()).fillInStackTrace();
}
}
public int getInt() throws SQLException {
if (getFieldData()==null) return INT_NULL_VALUE;
try {
return Integer.parseInt(getString().trim());
} catch (NumberFormatException nfex) {
throw (SQLException) createException(
INT_CONVERSION_ERROR+" "+getString().trim()).fillInStackTrace();
}
}
public long getLong() throws SQLException {
if (getFieldData()==null) return LONG_NULL_VALUE;
try {
return Long.parseLong(getString().trim());
}
catch (NumberFormatException nfex) {
throw (SQLException) createException(
LONG_CONVERSION_ERROR+" "+getString().trim()).fillInStackTrace();
}
}
public BigDecimal getBigDecimal() throws SQLException {
if (getFieldData()==null) return BIGDECIMAL_NULL_VALUE;
/**@todo check what exceptions can be thrown here */
return new BigDecimal(getString().trim());
}
public float getFloat() throws SQLException {
if (getFieldData()==null) return FLOAT_NULL_VALUE;
try {
return Float.parseFloat(getString().trim());
}
catch (NumberFormatException nfex) {
throw (SQLException) createException(
FLOAT_CONVERSION_ERROR+" "+getString().trim()).fillInStackTrace();
}
}
public double getDouble() throws SQLException {
if (getFieldData()==null) return DOUBLE_NULL_VALUE;
try {
return Double.parseDouble(getString().trim());
}
catch (NumberFormatException nfex) {
throw (SQLException) createException(
DOUBLE_CONVERSION_ERROR+" "+getString().trim()).fillInStackTrace();
}
}
//----- getBoolean, getString and getObject code
public boolean getBoolean() throws SQLException {
if (getFieldData()==null) return BOOLEAN_NULL_VALUE;
final String trimmedValue = getString().trim();
return trimmedValue.equalsIgnoreCase(LONG_TRUE) ||
trimmedValue.equalsIgnoreCase(SHORT_TRUE) ||
trimmedValue.equalsIgnoreCase(SHORT_TRUE_2) ||
trimmedValue.equalsIgnoreCase(SHORT_TRUE_3);
}
public String getString() throws SQLException {
if (getFieldData()==null) return STRING_NULL_VALUE;
return field.decodeString(getFieldData(), javaEncoding, mappingPath);
}
//----- getXXXStream code
public InputStream getBinaryStream() throws SQLException {
if (getFieldData()==null) return STREAM_NULL_VALUE;
return new ByteArrayInputStream(getFieldData());
}
public InputStream getUnicodeStream() throws SQLException {
if (getFieldData()==null) return STREAM_NULL_VALUE;
return getBinaryStream();
}
public InputStream getAsciiStream() throws SQLException {
if (getFieldData()==null) return STREAM_NULL_VALUE;
return getBinaryStream();
}
public byte[] getBytes() throws SQLException {
if (getFieldData()==null) return BYTES_NULL_VALUE;
return getFieldData();
}
//----- getDate, getTime and getTimestamp code
public Date getDate(Calendar cal) throws SQLException {
if (getFieldData()==null) return DATE_NULL_VALUE;
return field.decodeDate(getDate(),cal);
}
public Date getDate() throws SQLException {
if (getFieldData()==null) return DATE_NULL_VALUE;
return Date.valueOf(getString().trim());
}
public Time getTime(Calendar cal) throws SQLException {
if (getFieldData()==null) return TIME_NULL_VALUE;
return field.decodeTime(getTime(),cal, isInvertTimeZone());
}
public Time getTime() throws SQLException {
if (getFieldData()==null) return TIME_NULL_VALUE;
return Time.valueOf(getString().trim());
}
public Timestamp getTimestamp(Calendar cal) throws SQLException {
if (getFieldData()==null) return TIMESTAMP_NULL_VALUE;
return field.decodeTimestamp(getTimestamp(),cal, isInvertTimeZone());
}
public Timestamp getTimestamp() throws SQLException {
if (getFieldData()==null) return TIMESTAMP_NULL_VALUE;
return Timestamp.valueOf(getString().trim());
}
//--- setXXX methods
//----- Math code
public void setByte(byte value) throws SQLException {
setString(Byte.toString(value));
}
public void setShort(short value) throws SQLException {
setString(Short.toString(value));
}
public void setInteger(int value) throws SQLException {
setString(Integer.toString(value));
}
public void setLong(long value) throws SQLException {
setString(Long.toString(value));
}
public void setFloat(float value) throws SQLException {
setString(Float.toString(value));
}
public void setDouble(double value) throws SQLException {
setString(Double.toString(value));
}
public void setBigDecimal(BigDecimal value) throws SQLException {
if (value == BIGDECIMAL_NULL_VALUE) {
setNull();
return;
}
setString(value.toString());
}
//----- setBoolean, setString and setObject code
public void setBoolean(boolean value) throws SQLException {
if (possibleCharLength > 4) {
setString(value ? LONG_TRUE : LONG_FALSE);
} else if (possibleCharLength >= 1) {
setString(value ? SHORT_TRUE : SHORT_FALSE);
}
}
public void setString(String value) throws SQLException {
if (value == null) {
setNull();
return;
}
setFieldData(field.encodeString(value,javaEncoding, mappingPath));
}
//----- setXXXStream code
public void setAsciiStream(InputStream in, int length) throws SQLException {
setBinaryStream(in, length);
}
public void setUnicodeStream(InputStream in, int length) throws SQLException {
setBinaryStream(in, length);
}
public void setBinaryStream(InputStream in, int length) throws SQLException {
if (in == STREAM_NULL_VALUE) {
setNull();
return;
}
if (length > field.sqllen)
throw new DataTruncation(-1, true, false, length, field.sqllen);
try {
ByteArrayOutputStream out = new ByteArrayOutputStream();
byte[] buff = new byte[4096];
int counter = 0;
int toRead = length;
while ((counter = in.read(buff, 0, toRead > buff.length ? buff.length : toRead)) != -1) {
out.write(buff, 0, counter);
toRead -= counter;
}
setBytes(out.toByteArray());
}
catch (IOException ioex) {
throw (SQLException) createException(
BINARY_STREAM_CONVERSION_ERROR).fillInStackTrace();
}
}
public void setCharacterStream(Reader in, int length) throws SQLException {
if (in == READER_NULL_VALUE) {
setNull();
return;
}
try {
StringWriter out = new StringWriter();
char[] buff = new char[4096];
int counter = 0;
while ((counter = in.read(buff)) != -1)
out.write(buff, 0, counter);
String outString = out.toString();
setString(outString.substring(0, length));
}
catch (IOException ioex) {
throw (SQLException) createException(
CHARACTER_STREAM_CONVERSION_ERROR).fillInStackTrace();
}
}
public void setBytes(byte[] value) throws SQLException {
if (value == BYTES_NULL_VALUE) {
setNull();
return;
}
setFieldData(value);
if (value.length > field.sqllen)
throw new DataTruncation(-1, true, false, value.length, field.sqllen);
}
//----- setDate, setTime and setTimestamp code
public void setDate(Date value, Calendar cal) throws SQLException {
if (value == DATE_NULL_VALUE) {
setNull();
return;
}
setDate(field.encodeDate(value,cal));
}
public void setDate(Date value) throws SQLException {
if (value == DATE_NULL_VALUE) {
setNull();
return;
}
setString(value.toString());
}
public void setTime(Time value, Calendar cal) throws SQLException {
if (value == TIME_NULL_VALUE) {
setNull();
return;
}
setTime(field.encodeTime(value,cal, isInvertTimeZone()));
}
public void setTime(Time value) throws SQLException {
if (value == TIME_NULL_VALUE) {
setNull();
return;
}
setString(value.toString());
}
public void setTimestamp(Timestamp value, Calendar cal) throws SQLException {
if (value == TIMESTAMP_NULL_VALUE) {
setNull();
return;
}
setTimestamp(field.encodeTimestamp(value,cal, isInvertTimeZone()));
}
public void setTimestamp(Timestamp value) throws SQLException {
if (value == TIMESTAMP_NULL_VALUE) {
setNull();
return;
}
setString(value.toString());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy