*/
public void setNull(int parameterIndex, int sqlType) throws SQLException
{
- bind(parameterIndex, "null", PG_TEXT);
+ String l_pgType;
+ switch (sqlType)
+ {
+ case Types.INTEGER:
+ l_pgType = PG_INTEGER;
+ break;
+ case Types.TINYINT:
+ case Types.SMALLINT:
+ l_pgType = PG_INT2;
+ break;
+ case Types.BIGINT:
+ l_pgType = PG_INT8;
+ break;
+ case Types.REAL:
+ case Types.FLOAT:
+ l_pgType = PG_FLOAT;
+ break;
+ case Types.DOUBLE:
+ l_pgType = PG_DOUBLE;
+ break;
+ case Types.DECIMAL:
+ case Types.NUMERIC:
+ l_pgType = PG_NUMERIC;
+ break;
+ case Types.CHAR:
+ case Types.VARCHAR:
+ case Types.LONGVARCHAR:
+ l_pgType = PG_TEXT;
+ break;
+ case Types.DATE:
+ l_pgType = PG_DATE;
+ break;
+ case Types.TIME:
+ l_pgType = PG_TIME;
+ break;
+ case Types.TIMESTAMP:
+ l_pgType = PG_TIMESTAMPTZ;
+ break;
+ case Types.BINARY:
+ case Types.VARBINARY:
+ l_pgType = PG_BYTEA;
+ break;
+ case Types.OTHER:
+ l_pgType = PG_TEXT;
+ break;
+ default:
+ l_pgType = PG_TEXT;
+ }
+ bind(parameterIndex, "null", l_pgType);
}
/*
public void setBigDecimal(int parameterIndex, BigDecimal x) throws SQLException
{
if (x == null)
- setNull(parameterIndex, Types.OTHER);
+ setNull(parameterIndex, Types.DECIMAL);
else
{
bind(parameterIndex, x.toString(), PG_NUMERIC);
{
// if the passed string is null, then set this column to null
if (x == null)
- setNull(parameterIndex, Types.OTHER);
+ setNull(parameterIndex, Types.VARCHAR);
else
{
// use the shared buffer object. Should never clash but this makes
//Version 7.2 supports the bytea datatype for byte arrays
if (null == x)
{
- setNull(parameterIndex, Types.OTHER);
+ setNull(parameterIndex, Types.VARBINARY);
}
else
{
{
if (null == x)
{
- setNull(parameterIndex, Types.OTHER);
+ setNull(parameterIndex, Types.DATE);
}
else
{
{
if (null == x)
{
- setNull(parameterIndex, Types.OTHER);
+ setNull(parameterIndex, Types.TIME);
}
else
{
{
if (null == x)
{
- setNull(parameterIndex, Types.OTHER);
+ setNull(parameterIndex, Types.TIMESTAMP);
}
else
{
{
if (x == null)
{
- setNull(parameterIndex, Types.OTHER);
+ setNull(parameterIndex, targetSqlType);
return ;
}
switch (targetSqlType)
{
if (x == null)
{
- setNull(parameterIndex, Types.OTHER);
+ int l_sqlType;
+ if (x instanceof String)
+ l_sqlType = Types.VARCHAR;
+ else if (x instanceof BigDecimal)
+ l_sqlType = Types.DECIMAL;
+ else if (x instanceof Short)
+ l_sqlType = Types.SMALLINT;
+ else if (x instanceof Integer)
+ l_sqlType = Types.INTEGER;
+ else if (x instanceof Long)
+ l_sqlType = Types.BIGINT;
+ else if (x instanceof Float)
+ l_sqlType = Types.FLOAT;
+ else if (x instanceof Double)
+ l_sqlType = Types.DOUBLE;
+ else if (x instanceof byte[])
+ l_sqlType = Types.BINARY;
+ else if (x instanceof java.sql.Date)
+ l_sqlType = Types.DATE;
+ else if (x instanceof Time)
+ l_sqlType = Types.TIME;
+ else if (x instanceof Timestamp)
+ l_sqlType = Types.TIMESTAMP;
+ else if (x instanceof Boolean)
+ l_sqlType = Types.OTHER;
+ else
+ l_sqlType = Types.OTHER;
+
+ setNull(parameterIndex, l_sqlType);
return ;
}
if (x instanceof String)
private static final String PG_DATE = "date";
private static final String PG_TIME = "time";
private static final String PG_TIMESTAMPTZ = "timestamptz";
+ private static final String PG_BYTEA = "bytea";
}