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

com.frameworkset.common.poolman.Record Maven / Gradle / Ivy

/*
 *  Copyright 2008 biaoping.yin
 *
 *  Licensed under the Apache License, Version 2.0 (the "License");
 *  you may not use this file except in compliance with the License.
 *  You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 *  Unless required by applicable law or agreed to in writing, software
 *  distributed under the License is distributed on an "AS IS" BASIS,
 *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *  See the License for the specific language governing permissions and
 *  limitations under the License.  
 */
package com.frameworkset.common.poolman;

import com.frameworkset.common.poolman.handle.ValueExchange;
import com.frameworkset.common.poolman.sql.PoolManResultSetMetaData.WrapInteger;
import com.frameworkset.common.poolman.util.SQLUtil.DBHashtable;
import com.frameworkset.util.ValueObjectUtil;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import java.io.*;
import java.math.BigDecimal;
import java.sql.*;
import java.util.Calendar;
import java.util.Map;
/**
 * 
 * 
 * 

Title: Record.java

* *

Description: 封装每条记录的详细信息

* *

Copyright: Copyright (c) 2007

* * @Date Oct 28, 2008 10:30:27 AM * @author biaoping.yin * @version 1.0 */ public class Record extends DBHashtable{ private String[] fields; private Map sameCols = null; public Record(int i) { super(i,false); } public Record(boolean columnLableUpperCase,int i,String[] fields,Map sameCols) { super(i,columnLableUpperCase); this.fields = fields; if(sameCols != null && sameCols.size() > 0) this.sameCols = sameCols; } public Record(String[] fields,Map sameCols) { super(); this.fields = fields; if(sameCols != null && sameCols.size() > 0) this.sameCols = sameCols; } public Record() { super(); } /** * 设置记录对应的数据库原始记录行号 */ private int rowid; public void setRowid(int rowid) { this.rowid = rowid; } public int getRowid() { return rowid; } public Record(int initialCapacity, float loadFactor,String[] fields,Map sameCols) { super(initialCapacity,loadFactor); this.fields = fields; if(sameCols != null && sameCols.size() > 0) this.sameCols = sameCols; } public Record(int initialCapacity, float loadFactor) { super(initialCapacity,loadFactor); } private boolean isnull = true; public Record(Map t) { super(t); if(t != null) isnull = false; } public Record(Map t,String[] fields) { super(t); if(t != null) isnull = false; this.fields = fields; } // private Map data = new HashMap(); private static Logger log = LoggerFactory.getLogger(Record.class); /** * Retrieves whether the last OUT parameter read had the value of * SQL NULL. Note that this method should be called only after * calling a getter method; otherwise, there is no value to use in * determining whether it is null or not. * * @return true if the last parameter read was SQL * NULL; false otherwise * @exception SQLException if a database access error occurs */ public boolean wasNull() throws SQLException { return isnull; } /** * Retrieves the value of the designated JDBC CHAR, * VARCHAR, or LONGVARCHAR parameter as a * String in the Java programming language. *

* For the fixed-length type JDBC CHAR, * the String object * returned has exactly the same value the JDBC * CHAR value had in the * database, including any padding added by the database. * * @param parameterIndex * 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, * the result * is null. * @exception SQLException if a database access error occurs * @see #setString */ public String getString(int parameterIndex) throws SQLException { Object object = this.getObject(parameterIndex); return ValueExchange.getStringFromObject(object); } /** * Retrieves the value of the designated JDBC BIT parameter as a * boolean in the Java programming language. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, * the result is false. * @exception SQLException if a database access error occurs * @see #setBoolean */ public boolean getBoolean(int parameterIndex) throws SQLException { Boolean value = (Boolean)this.getObject(parameterIndex); if(value != null) { return value.booleanValue(); } throw new SQLException("getBoolean(" + parameterIndex + ") failed:value=null."); } /** * Retrieves the value of the designated JDBC TINYINT parameter * as a byte in the Java programming language. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is 0. * @exception SQLException if a database access error occurs * @see #setByte */ public byte getByte(int parameterIndex) throws SQLException { Byte byte_ = (Byte)this.getObject(parameterIndex); if(byte_ != null) return byte_.byteValue(); throw new SQLException("getByte(" + parameterIndex + ") failed:value=null."); } /** * Retrieves the value of the designated JDBC SMALLINT parameter * as a short in the Java programming language. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is 0. * @exception SQLException if a database access error occurs * @see #setShort */ public short getShort(int parameterIndex) throws SQLException { Object value = this.getObject(parameterIndex); return getShortFromObject(value); // Short byte_ = (Short)this.getObject(parameterIndex); // if(byte_ != null) // return byte_.byteValue(); // throw new SQLException("getShort(" + parameterIndex + ") failed:value=null."); } public short getShortFromObject(Object value) throws SQLException { if(value == null) return 0; else if(value instanceof Short) { Short s = (Short)value; return s.shortValue(); } if(value instanceof Integer) { Integer data = (Integer)value; return data.shortValue(); } else if(value instanceof BigDecimal) { BigDecimal b = (BigDecimal)value; return b.shortValue(); } else if(value instanceof Double) { Double b = (Double)value; return b.shortValue(); } else if(value instanceof Float) { Float f = (Float)value; return f.shortValue(); } else if(value instanceof Long) { Long l = (Long)value; return l.shortValue(); } else { String i = String.valueOf(value); try { return Short.parseShort(i); } catch(Exception e) { throw new NestedSQLException(e); } } } public int getIntFromObject(Object value) throws SQLException { if(value == null) return 0; else if(value instanceof Integer) { Integer data = (Integer)value; return data.intValue(); } else if(value instanceof Short) { Short s = (Short)value; return s.intValue(); } else if(value instanceof BigDecimal) { BigDecimal b = (BigDecimal)value; return b.intValue(); } else if(value instanceof Double) { Double b = (Double)value; return b.intValue(); } else if(value instanceof Float) { Float f = (Float)value; return f.intValue(); } else if(value instanceof Long) { Long l = (Long)value; return l.intValue(); } else { String i = String.valueOf(value); try { return Integer.parseInt(i); } catch(Exception e) { throw new NestedSQLException(e); } } } public float getFloatFromObject(Object value) throws SQLException { if(value == null) return 0; else if(value instanceof Float) { Float f = (Float)value; return f.floatValue(); } if(value instanceof Integer) { Integer data = (Integer)value; return data.floatValue(); } else if(value instanceof BigDecimal) { BigDecimal b = (BigDecimal)value; return b.floatValue(); } else if(value instanceof Short) { Short s = (Short)value; return s.floatValue(); } else if(value instanceof Long) { Long l = (Long)value; return l.floatValue(); } else if(value instanceof Double) { Double l = (Double)value; return l.floatValue(); } else { String i = String.valueOf(value); try { return Float.parseFloat(i); } catch(Exception e) { throw new NestedSQLException(e); } } } public double getDoubleFromObject(Object value) throws SQLException { if(value == null) return 0; else if(value instanceof Double) { Double l = (Double)value; return l.doubleValue(); } else if(value instanceof Float) { Float f = (Float)value; return f.doubleValue(); } if(value instanceof Integer) { Integer data = (Integer)value; return data.doubleValue(); } else if(value instanceof BigDecimal) { BigDecimal b = (BigDecimal)value; return b.doubleValue(); } else if(value instanceof Short) { Short s = (Short)value; return s.doubleValue(); } else if(value instanceof Long) { Long l = (Long)value; return l.doubleValue(); } else { String i = String.valueOf(value); try { return Double.parseDouble(i); } catch(Exception e) { throw new NestedSQLException(e); } } } /** * Retrieves the value of the designated JDBC INTEGER parameter * as an int in the Java programming language. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is 0. * @exception SQLException if a database access error occurs * @see #setInt */ public int getInt(int parameterIndex) throws SQLException { // if(Integer ) Object value = this.getObject(parameterIndex); return getIntFromObject(value); // throw new SQLException("getInt(" + parameterIndex + ") failed:value=null."); } /** * Retrieves the value of the designated JDBC BIGINT parameter * as a long in the Java programming language. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is 0. * @exception SQLException if a database access error occurs * @see #setLong */ public long getLong(int parameterIndex) throws SQLException { Object value = this.getObject(parameterIndex); return getLongFromObject(value); // Long data = (Long)this.getObject(parameterIndex); // if(data != null) // { // return data.longValue(); // } // throw new SQLException("getInt(" + parameterIndex + ") failed:value=null."); } public long getLongFromObject(Object value) throws SQLException { if(value == null) return 0; if(value instanceof Long) { Long l = (Long)value; return l.longValue(); } else if(value instanceof Double) { Double l = (Double)value; return l.longValue(); } else if(value instanceof Integer) { Integer data = (Integer)value; return data.longValue(); } else if(value instanceof BigDecimal) { BigDecimal b = (BigDecimal)value; return b.longValue(); } else if(value instanceof Short) { Short s = (Short)value; return s.longValue(); } else if(value instanceof Float) { Float f = (Float)value; return f.longValue(); } else { String i = String.valueOf(value); try { return Long.parseLong(i); } catch(Exception e) { throw new NestedSQLException(e); } } } /** * Retrieves the value of the designated JDBC FLOAT parameter * as a float in the Java programming language. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is 0. * @exception SQLException if a database access error occurs * @see #setFloat */ public float getFloat(int parameterIndex) throws SQLException { Object value = this.getObject(parameterIndex); return getFloatFromObject( value); } /** * Retrieves the value of the designated JDBC DOUBLE parameter as a double * in the Java programming language. * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is 0. * @exception SQLException if a database access error occurs * @see #setDouble */ public double getDouble(int parameterIndex) throws SQLException { Object value = this.getObject(parameterIndex); return getDoubleFromObject(value); // if(data != null) // { // return data.doubleValue(); // } // throw new SQLException("getDouble(" + parameterIndex + ") failed:value=null."); } /** * Retrieves the value of the designated JDBC NUMERIC parameter as a * java.math.BigDecimal object with scale digits to * the right of the decimal point. * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @param scale the number of digits to the right of the decimal point * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @deprecated use getBigDecimal(int parameterIndex) * or getBigDecimal(String parameterName) * @see #setBigDecimal */ public BigDecimal getBigDecimal(int parameterIndex, int scale) throws SQLException { BigDecimal big = this.getBigDecimal(parameterIndex); if(big != null) return big.setScale(scale); return null; } /** * Retrieves the value of the designated JDBC BINARY or * VARBINARY parameter as an array of byte * values in the Java programming language. * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setBytes */ public byte[] getBytes(int parameterIndex) throws SQLException { Object bytes = this.getObject(parameterIndex); if(bytes instanceof byte[]) return (byte[])bytes; else { return ValueExchange.convertObjectToBytes(bytes); } // return (byte[]) this.getObject(parameterIndex); } /** * Retrieves the value of the designated JDBC DATE parameter as a * java.sql.Date object. * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setDate */ public java.sql.Date getDate(int parameterIndex) throws SQLException { Object date = this.getObject(parameterIndex); if(date == null) return null; if(date instanceof java.sql.Date) { return (java.sql.Date)date; } else if(date instanceof java.util.Date) { return new java.sql.Date(((java.util.Date)date).getTime()); } throw new SQLException("Record.getDate(" + parameterIndex +") failed: error data type["+date.getClass().getName()+","+ date +"]"); // return (java.sql.Date)this.getObject(parameterIndex); } /** * Retrieves the value of the designated JDBC TIME parameter as a * java.sql.Time object. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setTime */ public java.sql.Time getTime(int parameterIndex) throws SQLException { Object object = this.getObject(parameterIndex); if(object == null) return null; if(object instanceof java.sql.Time) return (java.sql.Time)object; if(object instanceof java.util.Date) { return new java.sql.Time(((java.util.Date)object).getTime()); } // return (java.sql.Time)this.getObject(parameterIndex); throw new SQLException("Record.getTime(" + parameterIndex +") failed: error data type["+object.getClass().getName()+","+ object +"]"); } /** * Retrieves the value of the designated JDBC TIMESTAMP parameter as a * java.sql.Timestamp object. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setTimestamp */ public java.sql.Timestamp getTimestamp(int parameterIndex) throws SQLException { // return (java.sql.Timestamp)this.getObject(parameterIndex); Object object = this.getObject(parameterIndex); if(object == null) return null; if(object instanceof java.sql.Timestamp) return (java.sql.Timestamp)object; if(object instanceof java.util.Date) { return new java.sql.Timestamp(((java.util.Date)object).getTime()); } // return (java.sql.Time)this.getObject(parameterIndex); throw new SQLException("Record.getTimestamp(" + parameterIndex +") failed: error data type["+object.getClass().getName()+","+ object +"]"); } //---------------------------------------------------------------------- // Advanced features: /** * * @param column * start from zero * @return 列索引对应的属性名称 * @throws SQLException */ private String seekField(int column) throws SQLException { // return f_temps[column]; if(column > fields.length || column < 0) throw new SQLException(new StringBuilder("column out of range:column=").append(column) .append(",fields.length=").append(fields.length ).toString()); if(this.sameCols == null || column == 0) return this.fields[column]; String temp = fields[column]; WrapInteger wi = (WrapInteger)sameCols.get(temp ); if(wi == null) return temp ; else return wi.getColumnName(column); } /** * Retrieves the value of the designated parameter as an Object * in the Java programming language. If the value is an SQL NULL, * the driver returns a Java null. *

* This method returns a Java object whose type corresponds to the JDBC * type that was registered for this parameter using the method * registerOutParameter. By registering the target JDBC * type as java.sql.Types.OTHER, this method can be used * to read database-specific abstract data types. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return A java.lang.Object holding the OUT parameter value * @exception SQLException if a database access error occurs * @see Types * @see #setObject */ public Object getObject(int parameterIndex) throws SQLException { if(this.fields != null) { return get(seekField(parameterIndex)); // return get(new Integer(parameterIndex)); } else { return get(new Integer(parameterIndex)); } } //--------------------------JDBC 2.0----------------------------- /** * Retrieves the value of the designated JDBC NUMERIC parameter as a * java.math.BigDecimal object with as many digits to the * right of the decimal point as the value contains. * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value in full precision. If the value is * SQL NULL, the result is null. * @exception SQLException if a database access error occurs * @see #setBigDecimal * @since 1.2 */ public BigDecimal getBigDecimal(int parameterIndex) throws SQLException { return (BigDecimal)getObject(parameterIndex); } /** * Returns an object representing the value of OUT parameter * i and uses map for the custom * mapping of the parameter value. *

* This method returns a Java object whose type corresponds to the * JDBC type that was registered for this parameter using the method * registerOutParameter. By registering the target * JDBC type as java.sql.Types.OTHER, this method can * be used to read database-specific abstract data types. * @param i 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, and so on * @param map the mapping from SQL type names to Java classes * @return a java.lang.Object holding the OUT parameter value * @exception SQLException if a database access error occurs * @see #setObject * @since 1.2 */ public Object getObject (int i, java.util.Map map) throws SQLException { return this.getObject(i); } public java.io.Reader getCharacterStream( int columnIndex) throws SQLException { Object object = this.getObject(columnIndex); if(object == null) return null; if(object instanceof java.io.Reader) return (java.io.Reader)object; else if(object instanceof java.sql.Clob) { Clob clob = (java.sql.Clob)object; return clob.getCharacterStream(); } // else if(object instanceof java.sql.Blob) // { // Blob clob = (java.sql.Blob)object; // return clob.getCharacterStream(); // } throw new SQLException("Error type cast column index["+columnIndex+"]:From [" + object.getClass().getName() + "] to [" + java.io.Reader.class.getName() + "]"); } /** * Retrieves the value of the designated column in the current row of this * ResultSet object as a stream of ASCII characters. The * value can then be read in chunks from the stream. This method is * particularly suitable for retrieving large LONGVARCHAR * values. The JDBC driver will do any necessary conversion from the * database format into ASCII. * *

* Note: All the data in the returned stream must be read prior to * getting the value of any other column. The next call to a getter method * implicitly closes the stream. Also, a stream may return 0 * when the method InputStream.available is called whether * there is data available or not. * * @param rowid * the first row is 0, the second is 1 * @param columnIndex * the first column is 0, the second is 1, ... * @return a Java input stream that delivers the database column value as a * stream of one-byte ASCII characters; if the value is SQL * NULL, the value returned is null * @exception SQLException * if a database access error occurs */ public java.io.InputStream getAsciiStream(int columnIndex) throws SQLException { // inrange(rowid, colName); Object value = this.getObject(columnIndex); if(value == null) { return null; } if(value instanceof java.io.InputStream) return (java.io.InputStream)value; if(value instanceof Clob) { Clob clob = (Clob)value; return clob.getAsciiStream(); // java.io.InputStream } else if(value instanceof Blob) { Blob clob = (Blob)value; return clob.getBinaryStream(); // java.io.InputStream } throw new SQLException("Error type cast column index["+columnIndex+"]:From [" + value.getClass().getName() + "] to [" + java.io.InputStream.class.getName() + "]"); // return allResults[getTrueRowid(rowid)].getBoolean(colName); // return (java.io.InputStream) getObject(rowid, columnIndex); } public java.io.InputStream getAsciiStream(String colName) throws SQLException { //inrange(rowid, colName); Object value = this.getObject(colName); if(value == null) { return null; } if(value instanceof java.io.InputStream) return (java.io.InputStream)value; if(value instanceof Clob) { Clob clob = (Clob)value; return clob.getAsciiStream(); // java.io.InputStream } else if(value instanceof Blob) { Blob clob = (Blob)value; return clob.getBinaryStream(); // java.io.InputStream } throw new SQLException("Error type cast column["+colName+"]:From [" + value.getClass().getName() + "] to [" + java.io.InputStream.class.getName() + "]"); //return allResults[getTrueRowid(rowid)].getBoolean(colName); //return (java.io.InputStream) getObject(rowid, columnIndex); } public java.io.Reader getCharacterStream(String columnName) throws SQLException { Object object = this.getObject(columnName); if(object == null) return null; if(object instanceof java.io.Reader) return (java.io.Reader)object; else if(object instanceof java.sql.Clob) { Clob clob = (java.sql.Clob)object; return clob.getCharacterStream(); } // else if(object instanceof java.sql.Blob) // { // Blob clob = (java.sql.Blob)object; // return clob.getCharacterStream(); // } throw new SQLException("Error type cast column["+columnName+"]:From [" + object.getClass().getName() + "] to [" + java.io.Reader.class.getName() + "]"); } /** * Retrieves the value of the designated column in the current row of this * ResultSet object as as a stream of two-byte Unicode * characters. The first byte is the high byte; the second byte is the low * byte. * * The value can then be read in chunks from the stream. This method is * particularly suitable for retrieving large LONGVARCHARvalues. * The JDBC driver will do any necessary conversion from the database format * into Unicode. * *

* Note: All the data in the returned stream must be read prior to * getting the value of any other column. The next call to a getter method * implicitly closes the stream. Also, a stream may return 0 * when the method InputStream.available is called, whether * there is data available or not. * * @param rowid * the first row is 0, the second is 1 * @param columnIndex * the first column is 0, the second is 1, ... * @return a Java input stream that delivers the database column value as a * stream of two-byte Unicode characters; if the value is SQL * NULL, the value returned is null * * @exception SQLException * if a database access error occurs * @deprecated use getCharacterStream in place of * getUnicodeStream */ public java.io.InputStream getUnicodeStream( int columnIndex) throws SQLException { Object value = this.getObject( columnIndex); if(value == null) return null; if(value instanceof Blob) { Blob blob = (Blob)value; return blob.getBinaryStream(); } else if(value instanceof Clob) { Clob blob = (Clob)value; return blob.getAsciiStream(); } throw new SQLException("Error type cast column index["+columnIndex+"]:From [" + value.getClass().getName() + "] to [" + java.io.InputStream.class.getName() + "]"); // return (java.io.InputStream) this.getObject(rowid, columnIndex); } /** * Retrieves the value of the designated column in the current row of this * ResultSet object as a binary stream of uninterpreted * bytes. The value can then be read in chunks from the stream. This method * is particularly suitable for retrieving large LONGVARBINARY * values. * *

* Note: All the data in the returned stream must be read prior to * getting the value of any other column. The next call to a getter method * implicitly closes the stream. Also, a stream may return 0 * when the method InputStream.available is called whether * there is data available or not. * * @param rowid * the first row is 0, the second is 1 * @param columnIndex * the first column is 0, the second is 1, ... * @return a Java input stream that delivers the database column value as a * stream of uninterpreted bytes; if the value is SQL * NULL, the value returned is null * @exception SQLException * if a database access error occurs */ public java.io.InputStream getBinaryStream(int columnIndex) throws SQLException { Object value = this.getObject( columnIndex); if(value == null) return null; if(value instanceof Blob) { Blob blob = (Blob)value; return blob.getBinaryStream(); } else if(value instanceof Clob) { Clob blob = (Clob)value; return blob.getAsciiStream(); } throw new SQLException("Error type cast column index["+columnIndex+"]:From [" + value.getClass().getName() + "] to [" + java.io.InputStream.class.getName() + "]"); // return (java.io.InputStream) this.getObject(rowid, columnIndex); } public java.io.InputStream getBinaryStream(String columnName) throws SQLException { Object value = this.getObject( columnName); if(value == null) return null; if(value instanceof Blob) { Blob blob = (Blob)value; return blob.getBinaryStream(); } else if(value instanceof Clob) { Clob blob = (Clob)value; return blob.getAsciiStream(); } throw new SQLException("Error type cast column["+columnName+"]:From [" + value.getClass().getName() + "] to [" + java.io.InputStream.class.getName() + "]"); //return (java.io.InputStream) this.getObject(rowid, columnIndex); } /** * Retrieves the value of the designated column in the current row of this * ResultSet object as as a stream of two-byte Unicode * characters. The first byte is the high byte; the second byte is the low * byte. * * The value can then be read in chunks from the stream. This method is * particularly suitable for retrieving large LONGVARCHARvalues. * The JDBC driver will do any necessary conversion from the database format * into Unicode. * *

* Note: All the data in the returned stream must be read prior to * getting the value of any other column. The next call to a getter method * implicitly closes the stream. Also, a stream may return 0 * when the method InputStream.available is called, whether * there is data available or not. * * @param rowid * the first row is 0, the second is 1 * @param columnIndex * the first column is 0, the second is 1, ... * @return a Java input stream that delivers the database column value as a * stream of two-byte Unicode characters; if the value is SQL * NULL, the value returned is null * * @exception SQLException * if a database access error occurs * @deprecated use getCharacterStream in place of * getUnicodeStream */ public java.io.InputStream getUnicodeStream( String columnName) throws SQLException { Object value = this.getObject( columnName); if(value == null) return null; if(value instanceof Blob) { Blob blob = (Blob)value; return blob.getBinaryStream(); } else if(value instanceof Clob) { Clob blob = (Clob)value; return blob.getAsciiStream(); } throw new SQLException("Error type cast column["+columnName+"]:From [" + value.getClass().getName() + "] to [" + java.io.InputStream.class.getName() + "]"); // return (java.io.InputStream) this.getObject(rowid, columnIndex); } /** * Retrieves the value of the designated JDBC REF(<structured-type>) * parameter as a {@link Ref} object in the Java programming language. * @param i 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @return the parameter value as a Ref object in the * Java programming language. If the value was SQL NULL, the value * null is returned. * @exception SQLException if a database access error occurs * @since 1.2 */ public Ref getRef (int i) throws SQLException { return (Ref)this.getObject(i); } /** * Retrieves the value of the designated JDBC BLOB parameter as a * {@link Blob} object in the Java programming language. * @param i 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, and so on * @return the parameter value as a Blob object in the * Java programming language. If the value was SQL NULL, the value * null is returned. * @exception SQLException if a database access error occurs * @since 1.2 */ public Blob getBlob (int i) throws SQLException { return (Blob)this.getObject(i); } /** * Retrieves the value of the designated JDBC CLOB parameter as a * Clob object in the Java programming language. * @param i 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, and * so on * @return the parameter value as a Clob object in the * Java programming language. If the value was SQL NULL, the * value null is returned. * @exception SQLException if a database access error occurs * @since 1.2 */ public Clob getClob (int i) throws SQLException { return (Clob)this.getObject(i); } /** * * Retrieves the value of the designated JDBC ARRAY parameter as an * {@link Array} object in the Java programming language. * @param i 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, and * so on * @return the parameter value as an Array object in * the Java programming language. If the value was SQL NULL, the * value null is returned. * @exception SQLException if a database access error occurs * @since 1.2 */ public Array getArray (int i) throws SQLException { return (Array)this.getObject(i); } /** * Retrieves the value of the designated JDBC DATE parameter as a * java.sql.Date object, using * the given Calendar object * to construct the date. * With a Calendar object, the driver * can calculate the date taking into account a custom timezone and locale. * If no Calendar object is specified, the driver uses the * default timezone and locale. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @param cal the Calendar object the driver will use * to construct the date * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setDate * @since 1.2 */ public java.sql.Date getDate(int parameterIndex, Calendar cal) throws SQLException { java.sql.Date date = this.getDate(parameterIndex); if(date != null) { cal.setTime(date); return new java.sql.Date(cal.getTimeInMillis()); // java.util.Date date_ = cal.getTime(); // return new java.sql.Date(date,cal); } return null; } /** * Retrieves the value of the designated JDBC TIME parameter as a * java.sql.Time object, using * the given Calendar object * to construct the time. * With a Calendar object, the driver * can calculate the time taking into account a custom timezone and locale. * If no Calendar object is specified, the driver uses the * default timezone and locale. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @param cal the Calendar object the driver will use * to construct the time * @return the parameter value; if the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setTime * @since 1.2 */ public java.sql.Time getTime(int parameterIndex, Calendar cal) throws SQLException { java.sql.Time time = this.getTime(parameterIndex); if(time != null) { cal.setTimeInMillis(time.getTime()); return new java.sql.Time(cal.getTimeInMillis()); } return null; } /** * Retrieves the value of the designated JDBC TIMESTAMP parameter as a * java.sql.Timestamp object, using * the given Calendar object to construct * the Timestamp object. * With a Calendar object, the driver * can calculate the timestamp taking into account a custom timezone and locale. * If no Calendar object is specified, the driver uses the * default timezone and locale. * * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1, * and so on * @param cal the Calendar object the driver will use * to construct the timestamp * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setTimestamp * @since 1.2 */ public java.sql.Timestamp getTimestamp(int parameterIndex, Calendar cal) throws SQLException { java.sql.Timestamp date = this.getTimestamp(parameterIndex); if(date != null) { cal.setTimeInMillis(date.getTime()); return new java.sql.Timestamp(cal.getTimeInMillis()); } return null; } /** * Retrieves the value of the designated JDBC DATALINK parameter as a * java.net.URL object. * * @param parameterIndex 存储过程返回的数据:the first parameter is 1, the second is 2 一般查询的结果集: the first parameter is 0, the second is 1,... * @return a java.net.URL object that represents the * JDBC DATALINK value used as the designated * parameter * @exception SQLException if a database access error occurs, * or if the URL being returned is * not a valid URL on the Java platform * @see #setURL * @since 1.4 */ public java.net.URL getURL(int parameterIndex) throws SQLException { return (java.net.URL)this.getObject(parameterIndex); } /** * Retrieves the value of a JDBC CHAR, VARCHAR, * or LONGVARCHAR parameter as a String in * the Java programming language. *

* For the fixed-length type JDBC CHAR, * the String object * returned has exactly the same value the JDBC * CHAR value had in the * database, including any padding added by the database. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setString * @since 1.4 */ public String getString(String parameterName) throws SQLException { Object object = this.getObject(parameterName); return ValueExchange.getStringFromObject(object); } /** * Retrieves the value of a JDBC BIT parameter as a * boolean in the Java programming language. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, the result * is false. * @exception SQLException if a database access error occurs * @see #setBoolean * @since 1.4 */ public boolean getBoolean(String parameterName) throws SQLException { Boolean value = (Boolean)this.getObject(parameterName); if(value != null) { return value.booleanValue(); } throw new SQLException("getBoolean(" + parameterName + ") failed:value=null."); } /** * Retrieves the value of a JDBC TINYINT parameter as a byte * in the Java programming language. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, the result * is 0. * @exception SQLException if a database access error occurs * @see #setByte * @since 1.4 */ public byte getByte(String parameterName) throws SQLException { Byte byte_ = (Byte)this.getObject(parameterName); if(byte_ != null) return byte_.byteValue(); throw new SQLException("getByte(" + parameterName + ") failed:value=null."); } /** * Retrieves the value of a JDBC SMALLINT parameter as a short * in the Java programming language. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, the result * is 0. * @exception SQLException if a database access error occurs * @see #setShort * @since 1.4 */ public short getShort(String parameterName) throws SQLException { Object value = this.getObject(parameterName); return getShortFromObject(value); } /** * Retrieves the value of a JDBC INTEGER parameter as an int * in the Java programming language. * * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, * the result is 0. * @exception SQLException if a database access error occurs * @see #setInt * @since 1.4 */ public int getInt(String parameterName) throws SQLException { // Integer data = (Integer)this.getObject(parameterName); // if(data != null) // { // return data.intValue(); // } // throw new SQLException("getInt(" + parameterName + ") failed:value=null."); Object value = this.getObject(parameterName); return getIntFromObject(value); } /** * Retrieves the value of a JDBC BIGINT parameter as a long * in the Java programming language. * * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, * the result is 0. * @exception SQLException if a database access error occurs * @see #setLong * @since 1.4 */ public long getLong(String parameterName) throws SQLException { // Long data = (Long)this.getObject(parameterName); // if(data != null) // { // return data.longValue(); // } // throw new SQLException("getInt(" + parameterName + ") failed:value=null."); Object value = this.getObject(parameterName); return getLongFromObject(value); } /** * Retrieves the value of a JDBC FLOAT parameter as a float * in the Java programming language. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, * the result is 0. * @exception SQLException if a database access error occurs * @see #setFloat * @since 1.4 */ public float getFloat(String parameterName) throws SQLException { Object value = this.getObject(parameterName); return getFloatFromObject( value); } /** * Retrieves the value of a JDBC DOUBLE parameter as a double * in the Java programming language. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, * the result is 0. * @exception SQLException if a database access error occurs * @see #setDouble * @since 1.4 */ public double getDouble(String parameterName) throws SQLException { Object value = this.getObject(parameterName); return getDoubleFromObject(value); } /** * Retrieves the value of a JDBC BINARY or VARBINARY * parameter as an array of byte values in the Java * programming language. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, the result is * null. * @exception SQLException if a database access error occurs * @see #setBytes * @since 1.4 */ public byte[] getBytes(String parameterName) throws SQLException { Object bytes = this.getObject(parameterName); if(bytes instanceof byte[]) return (byte[])bytes; else { return ValueExchange.convertObjectToBytes(bytes); } } /** * Retrieves the value of a JDBC DATE parameter as a * java.sql.Date object. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setDate * @since 1.4 */ public java.sql.Date getDate(String parameterName) throws SQLException { // return (java.sql.Date)this.getObject(parameterName); Object date = this.getObject(parameterName); if(date == null) return null; if(date instanceof java.sql.Date) { return (java.sql.Date)date; } else if(date instanceof java.util.Date) { return new java.sql.Date(((java.util.Date)date).getTime()); } throw new SQLException("Record.getDate(" + parameterName +") failed: error data type["+date.getClass().getName()+","+ date +"]"); } /** * Retrieves the value of a JDBC TIME parameter as a * java.sql.Time object. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setTime * @since 1.4 */ public java.sql.Time getTime(String parameterName) throws SQLException { // return (java.sql.Time)this.getObject(parameterName); Object object = this.getObject(parameterName); if(object == null) return null; if(object instanceof java.sql.Time) return (java.sql.Time)object; if(object instanceof java.util.Date) { return new java.sql.Time(((java.util.Date)object).getTime()); } // return (java.sql.Time)this.getObject(parameterIndex); throw new SQLException("Record.getTime(" + parameterName +") failed: error data type["+object.getClass().getName()+","+ object +"]"); } /** * Retrieves the value of a JDBC TIMESTAMP parameter as a * java.sql.Timestamp object. * @param parameterName the name of the parameter * @return the parameter value. If the value is SQL NULL, the result * is null. * @exception SQLException if a database access error occurs * @see #setTimestamp * @since 1.4 */ public java.sql.Timestamp getTimestamp(String parameterName) throws SQLException { // return (java.sql.Timestamp)this.getObject(parameterName); Object object = this.getObject(parameterName); if(object == null) return null; if(object instanceof java.sql.Timestamp) return (java.sql.Timestamp)object; if(object instanceof java.util.Date) { return new java.sql.Timestamp(((java.util.Date)object).getTime()); } // return (java.sql.Time)this.getObject(parameterIndex); throw new SQLException("Record.getTimestamp(" + parameterName +") failed: error data type["+object.getClass().getName()+","+ object +"]"); } /** * Retrieves the value of a parameter as an Object in the Java * programming language. If the value is an SQL NULL, the * driver returns a Java null. *

* This method returns a Java object whose type corresponds to the JDBC * type that was registered for this parameter using the method * registerOutParameter. By registering the target JDBC * type as java.sql.Types.OTHER, this method can be used * to read database-specific abstract data types. * @param parameterName the name of the parameter * @return A java.lang.Object holding the OUT parameter value. * @exception SQLException if a database access error occurs * @see Types * @since 1.4 */ public Object getObject(String parameterName) throws SQLException { if(columnLableUpperCase) { return get(parameterName.toUpperCase()); } else { return get(parameterName); } } /** * Retrieves the value of a JDBC NUMERIC parameter as a * java.math.BigDecimal object with as many digits to the * right of the decimal point as the value contains. * @param parameterName the name of the parameter * @return the parameter value in full precision. If the value is * SQL NULL, the result is null. * @exception SQLException if a database access error occurs * @since 1.4 */ public BigDecimal getBigDecimal(String parameterName) throws SQLException { return (BigDecimal)this.getObject(parameterName); } /** * Returns an object representing the value of OUT parameter * i and uses map for the custom * mapping of the parameter value. *

* This method returns a Java object whose type corresponds to the * JDBC type that was registered for this parameter using the method * registerOutParameter. By registering the target * JDBC type as java.sql.Types.OTHER, this method can * be used to read database-specific abstract data types. * @param parameterName the name of the parameter * @param map the mapping from SQL type names to Java classes * @return a java.lang.Object holding the OUT parameter value * @exception SQLException if a database access error occurs * @see #setObject * @since 1.4 */ public Object getObject (String parameterName, java.util.Map map) throws SQLException { // if(data != null) // { // return data.get(parameterName.toLowerCase()); // // } // return null; return get(parameterName.toLowerCase()); } /** * Retrieves the value of a JDBC REF(<structured-type>) * parameter as a {@link Ref} object in the Java programming language. * * @param parameterName the name of the parameter * @return the parameter value as a Ref object in the * Java programming language. If the value was SQL NULL, * the value null is returned. * @exception SQLException if a database access error occurs * @since 1.4 */ public Ref getRef (String parameterName) throws SQLException { return (Ref)this.getObject(parameterName); } /** * Retrieves the value of a JDBC BLOB parameter as a * {@link Blob} object in the Java programming language. * * @param parameterName the name of the parameter * @return the parameter value as a Blob object in the * Java programming language. If the value was SQL NULL, * the value null is returned. * @exception SQLException if a database access error occurs * @since 1.4 */ public Blob getBlob (String parameterName) throws SQLException { return (Blob)this.getObject(parameterName); } /** * Retrieves the value of a JDBC CLOB parameter as a * Clob object in the Java programming language. * @param parameterName the name of the parameter * @return the parameter value as a Clob object in the * Java programming language. If the value was SQL NULL, * the value null is returned. * @exception SQLException if a database access error occurs * @since 1.4 */ public Clob getClob (String parameterName) throws SQLException { return (Clob)this.getObject(parameterName); } /** * Retrieves the value of a JDBC ARRAY parameter as an * {@link Array} object in the Java programming language. * * @param parameterName the name of the parameter * @return the parameter value as an Array object in * Java programming language. If the value was SQL NULL, * the value null is returned. * @exception SQLException if a database access error occurs * @since 1.4 */ public Array getArray (String parameterName) throws SQLException { return (Array)this.getObject(parameterName); } /** * Retrieves the value of a JDBC DATE parameter as a * java.sql.Date object, using * the given Calendar object * to construct the date. * With a Calendar object, the driver * can calculate the date taking into account a custom timezone and locale. * If no Calendar object is specified, the driver uses the * default timezone and locale. * * @param parameterName the name of the parameter * @param cal the Calendar object the driver will use * to construct the date * @return the parameter value. If the value is SQL NULL, * the result is null. * @exception SQLException if a database access error occurs * @see #setDate * @since 1.4 */ public java.sql.Date getDate(String parameterName, Calendar cal) throws SQLException { java.sql.Date date = this.getDate(parameterName); if(date != null) { cal.setTime(date); return new java.sql.Date(cal.getTimeInMillis()); // java.util.Date date_ = cal.getTime(); // return new java.sql.Date(date,cal); } return null; } /** * Retrieves the value of a JDBC TIME parameter as a * java.sql.Time object, using * the given Calendar object * to construct the time. * With a Calendar object, the driver * can calculate the time taking into account a custom timezone and locale. * If no Calendar object is specified, the driver uses the * default timezone and locale. * * @param parameterName the name of the parameter * @param cal the Calendar object the driver will use * to construct the time * @return the parameter value; if the value is SQL NULL, the result is * null. * @exception SQLException if a database access error occurs * @see #setTime * @since 1.4 */ public java.sql.Time getTime(String parameterName, Calendar cal) throws SQLException { java.sql.Time time = this.getTime(parameterName); if(time != null) { cal.setTimeInMillis(time.getTime()); return new java.sql.Time(cal.getTimeInMillis()); } return null; } /** * Retrieves the value of a JDBC TIMESTAMP parameter as a * java.sql.Timestamp object, using * the given Calendar object to construct * the Timestamp object. * With a Calendar object, the driver * can calculate the timestamp taking into account a custom timezone and locale. * If no Calendar object is specified, the driver uses the * default timezone and locale. * * * @param parameterName the name of the parameter * @param cal the Calendar object the driver will use * to construct the timestamp * @return the parameter value. If the value is SQL NULL, the result is * null. * @exception SQLException if a database access error occurs * @see #setTimestamp * @since 1.4 */ public java.sql.Timestamp getTimestamp(String parameterName, Calendar cal) throws SQLException { java.sql.Timestamp date = this.getTimestamp(parameterName); if(date != null) { cal.setTimeInMillis(date.getTime()); return new java.sql.Timestamp(cal.getTimeInMillis()); } return null; } /** * Retrieves the value of a JDBC DATALINK parameter as a * java.net.URL object. * * @param parameterName the name of the parameter * @return the parameter value as a java.net.URL object in the * Java programming language. If the value was SQL NULL, the * value null is returned. * @exception SQLException if a database access error occurs, * or if there is a problem with the URL * @see #setURL * @since 1.4 */ public java.net.URL getURL(String parameterName) throws SQLException { return (java.net.URL)this.getObject(parameterName); } public void getFile(int index,File file) throws SQLException, IOException { Object value = this.getObject(index); this.getFile(value, file); } public void getFile(Object value,File file) throws SQLException { if (value == null) { return; } else { if (value instanceof Blob) { ValueObjectUtil.getFileFromBlob((Blob)value, file); } else if(value instanceof Clob) { ValueObjectUtil.getFileFromClob((Clob)value, file); } else if (value instanceof byte[]) { ValueObjectUtil.getFileFromBytes((byte[])value, file); } else if (value instanceof String) { ValueObjectUtil.getFileFromString((String)value, file); } else { ValueObjectUtil.getFileFromString(value.toString(), file); } } } public void getFile(String parameterName,File file) throws SQLException, IOException { Object value = this.getObject(parameterName); this.getFile(value, file); } /* * 获取序列化对象 */ public Serializable getSerializable(String field) throws SQLException { Blob blog = this.getBlob(field); if(blog == null) return null; Serializable object = null; InputStream in = null; java.io.ObjectInputStream objectin = null; try { in = blog.getBinaryStream(); objectin = new ObjectInputStream(in); object = (Serializable)objectin.readObject(); } catch(SQLException e) { throw e; } catch(Exception e) { throw new NestedSQLException(e); } finally { if(in != null) try { in.close(); } catch (IOException e) { // // TODO Auto-generated catch block // e.printStackTrace(); } if(objectin != null) try { objectin.close(); } catch (IOException e) { // // TODO Auto-generated catch block // e.printStackTrace(); } } return object; } public Serializable getSerializable(int parameterIndex) throws SQLException { Blob blog = this.getBlob(parameterIndex); if(blog == null) return null; Serializable object = null; InputStream in = null; java.io.ObjectInputStream objectin = null; try { in = blog.getBinaryStream(); objectin = new ObjectInputStream(in); object = (Serializable)objectin.readObject(); } catch(SQLException e) { throw e; } catch(Exception e) { throw new NestedSQLException(e); } finally { if(in != null) try { in.close(); } catch (IOException e) { // // TODO Auto-generated catch block // e.printStackTrace(); } if(objectin != null) try { objectin.close(); } catch (IOException e) { // // TODO Auto-generated catch block // e.printStackTrace(); } } return object; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy