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

com.frameworkset.common.poolman.sql.PoolManResultSetMetaData Maven / Gradle / Ivy

package com.frameworkset.common.poolman.sql;

import com.frameworkset.common.poolman.handle.RowHandlerException;
import com.frameworkset.common.poolman.management.PoolManConfiguration;
import com.frameworkset.common.poolman.util.JDBCPool;
import com.frameworkset.orm.adapter.DB;
import org.frameworkset.util.ClassUtil;

import java.sql.SQLException;
import java.util.HashMap;
import java.util.Map;



/** PoolManResultSetMetaData takes a copy of a java.sql.ResultSetMetaData
 * for later usage. Some databases use the underlying ResultSet for
 * ResultSetMetaData information, so closing the ResultSet makes the
 * ResultSetMetaData unavailable. Given a database-specific ResultSetMetaData
 * object, this class creates a copy of the values and makes them available
 * long after the ResultSet has been closed.
 *
 * This class is used by PoolManStatement and is stored in the cache.
 *
 */
public class PoolManResultSetMetaData implements java.sql.ResultSetMetaData, java.io.Serializable {
    private boolean columnLableUpperCase;
    private int _columnCount;
    private String[] _columnTypeName;
    private String[] _columnClassName;
//    private int[] _scale;
    private String[] _columnLabel;
    private String[] _columnLabel_upper;
//    private String[] _columnLabel_lower;

//    private boolean[] _autoIncrement;
//    private int[] _columnDisplaySize;
//    private String[] _catalogName;
    private String[] _columnName;
//    private boolean[] _writable;
//    private boolean[] _searchable;
    private int[] _columnType;
//    private boolean[] _currency;
//    private String[] _tableName;
//    private int[] _nullable;
//    private boolean[] _signed;
//    private boolean[] _readOnly;
//    private boolean[] _definitelyWritable;
//    private int[] _precision;
//    private String[] _schemaName;
//    private boolean[] _caseSensitive;
    /**
     * 存储符合java规范java属性名称,转换规则为:aaa_bb_cc-->aaaBbCc
     */
    private String columnJavaName[];
    
    /**
     * 执行查询时,保存相同的字段出现在查询字段列表中的位置信息
     * 
     * 比如
     * Map
     */
    private Map samecols ;
    

    // used for storing error information from when getColumnClassName() fails
    private String _sqlReason;
    private String _sqlState;
    private int _sqlVendorCode;

    public static PoolManResultSetMetaData getCopy(JDBCPool pool, java.sql.ResultSetMetaData original) throws java.sql.SQLException {
        if (original instanceof PoolManResultSetMetaData)
            return (PoolManResultSetMetaData)original;
        else
            return new PoolManResultSetMetaData(pool,original);
    }
    
    public static PoolManResultSetMetaData getCopy(java.sql.ResultSetMetaData original) throws java.sql.SQLException {
        if (original instanceof PoolManResultSetMetaData)
            return (PoolManResultSetMetaData)original;
        else
            return new PoolManResultSetMetaData(null,original);
    }

    public boolean isColumnLableUpperCase() {
        return columnLableUpperCase;
    }

    public static class WrapInteger
    {
//        int i = 0;
        private String columnName;
        public String getColumnName(int index) {
            return (String)indexs.get(new Integer(index));
        }

        Map indexs = new HashMap();
        int count = 1;
        public WrapInteger(int count,int index,String columnName)
        {
            this.count = count;
            
            indexs.put(new Integer(index),columnName);
            this.columnName = columnName;
        }
       
        public void increament(int index)
        {
            count ++;
            indexs.put(new Integer(index),buildUUColname(columnName,index));;
        }
        
        public boolean containsamecol()
        {
            return count > 1;
        }
        
        public Map getIndexs()
        {
            return this.indexs;
        }
        
        public int getCount()
        {
            return count;
        }
        
        
        
    }
    public static final String col_uuid_split = "#$_";
    
    public static String buildUUColname(String name,int id)
    {
        return new StringBuilder(name).append(col_uuid_split ).append(id).toString();
    }
    private PoolManResultSetMetaData(JDBCPool pool,java.sql.ResultSetMetaData other) throws java.sql.SQLException {
//        resultSetMetaData = other;
        columnLableUpperCase = pool.getJDBCPoolMetadata().isColumnLableUpperCase();
        DB db = pool.getDbAdapter();
        _columnCount = other.getColumnCount();

        _columnTypeName = new String[_columnCount];
        _columnClassName = new String[_columnCount];
//        _scale = new int[_columnCount];
        _columnLabel = new String[_columnCount];
         _columnLabel_upper = new String[_columnCount];
//        _columnLabel_lower = new String[_columnCount];
//        _autoIncrement = new boolean[_columnCount];
//        _columnDisplaySize = new int[_columnCount];
//        _catalogName = new String[_columnCount];
        _columnName = new String[_columnCount];
//        _writable = new boolean[_columnCount];
//        _searchable = new boolean[_columnCount];
        _columnType = new int[_columnCount];
//        _currency = new boolean[_columnCount];
//        _tableName = new String[_columnCount];
//        _nullable = new int[_columnCount];
//        _signed = new boolean[_columnCount];
//        _readOnly = new boolean[_columnCount];
//        _definitelyWritable = new boolean[_columnCount];
//        _precision = new int[_columnCount];
//        _schemaName = new String[_columnCount];
//        _caseSensitive = new boolean[_columnCount];
        samecols = new HashMap();
        
        if(PoolManConfiguration.isColumnNameMapping())
        {
        	columnJavaName = new String[_columnCount];
        }
        Map testM = new HashMap(); 
        
        String columnLabel = null;
        String columnName = null;
        for (int c = 0; c < _columnCount; c++) {
        	int rc = c + 1;
            _columnTypeName[c] = other.getColumnTypeName(rc);

            if (_columnClassName != null) {
                // this only works on JDBC compliant drivers
                try {
                    _columnClassName[c] = other.getColumnClassName(rc);
                } catch (java.sql.SQLException x) {
                    _columnClassName = null; // don't try again!
                    _sqlReason = x.getMessage();
                    _sqlState = x.getSQLState();
                    _sqlVendorCode = x.getErrorCode();
                } catch (Throwable e) {
                    _columnClassName = null; // don't try again!
                }

            }

//            _scale[c] = other.getScale(rc);
            columnName = other.getColumnName(rc);
            _columnName[c] = columnName;
            columnLabel = other.getColumnLabel(rc);
            if(columnLabel == null || columnLabel.equals("")) {
                columnLabel = columnName;
            }
            _columnLabel[c] = columnLabel;
            _columnLabel_upper[c] =  columnLabel.toUpperCase();
//            _columnLabel_lower[c] = columnLabel.toLowerCase();
           if(PoolManConfiguration.isColumnNameMapping())
           {
        	   this.columnJavaName[c] = ClassUtil.genJavaName(columnLabel);
           }
//            Integer idx = new Integer(c);
            String label = columnLableUpperCase?_columnLabel_upper[c]:columnLabel;
            WrapInteger wi = (WrapInteger)testM.get(label);
            if(wi == null)
            {
                wi = new WrapInteger(1,c,label);
                testM.put(label, wi);
            }
            else
            {
                wi.increament(c);
            }
//            _autoIncrement[c] = other.isAutoIncrement(rc);
//            _columnDisplaySize[c] = other.getColumnDisplaySize(rc);

//            try {
//                _catalogName[c] = other.getCatalogName(rc);
//            } catch (Exception e) {
//            }
//            if (_catalogName[c] == null)
//                _catalogName[c] = "";


            
            if(db != null)
            {
//            	_writable[c] = db.isWritebable(other,rc);
//            	_searchable[c] = db.isSearchable(other,rc);
//            	 _signed[c] = db.isSigned(other,rc);
//            	 _definitelyWritable[c] = db.isDefinitelyWritable(other,rc);
            }
            else
            {
//            	try {
//					_writable[c] = other.isWritable(rc);
//				} catch (Exception e) {
//					
//				}
//            	try {
//            		 _searchable[c] = other.isSearchable(rc);
//				} catch (Exception e) {
//					
//				}
//            	
//            	try {
//            		 _signed[c] = other.isSigned(rc);
//				} catch (Exception e) {
//					
//				}
//            	try {
//            		_definitelyWritable[c] = other.isDefinitelyWritable(rc);
//				} catch (Exception e) {
//					
//				}
            	 
            	 
            }
           
            _columnType[c] = other.getColumnType(rc);
//            _currency[c] = other.isCurrency(rc);

//            try {
//                _tableName[c] = other.getTableName(rc);
//            } catch (Exception e) {
//            }
//            if (_tableName[c] == null)
//                _tableName[c] = "";

//            _nullable[c] = other.isNullable(rc);
//          
//            _readOnly[c] = other.isReadOnly(rc);
//           
//            try
//            {
//                _precision[c] = other.getPrecision(rc);
//            }
//            catch(Exception e)
//            {
//                
//            }

//            try {
//                _schemaName[c] = other.getSchemaName(rc);
//            } catch (Exception e) {
//            }
//            if (_schemaName[c] == null)
//                _schemaName[c] = "";
//
//            _caseSensitive[c] = false;//other.isCaseSensitive(rc);,fixed mysql 每次都会向mysql后台发送SHOW FULL COLUMNS FROM 指令
        }

        for (int c = 0; c < _columnCount; c++) {
//            Integer idx = new Integer(c);
            String name =  columnLableUpperCase?_columnLabel_upper[c]:_columnLabel[c];
            WrapInteger wi = (WrapInteger)testM.get(name);
            if(wi.containsamecol() && !samecols.containsKey(name))
            {
                samecols.put( name, wi);
            }
        }
        testM = null;
    }
    
    public Map getSamecols() {
        return samecols;
    }
    public WrapInteger getSameColumns(int colIndex)
    {
        return  getSameColumns(this.getColumnLabelUpper(colIndex));
//        return  (WrapInteger)samecols.get(new Integer(colIndex));
    }
    public WrapInteger getSameColumnsByIndex(int colIndex)
    {
        return  getSameColumns(this.getColumnLabelUpperByIndex(colIndex));
//        return  (WrapInteger)samecols.get(new Integer(colIndex));
    }
    
    public WrapInteger getSameColumns(String colName)
    {
        return  (WrapInteger)samecols.get(colName);
//        return   getSameColumns((getColumnIndex(colName)));
    }
    


    public int getColumnCount() throws java.sql.SQLException {
        return _columnCount;
    }
    
    public int getColumnCounts()  {
        return _columnCount;
    }

    public java.lang.String getColumnTypeName(int column) throws java.sql.SQLException {
        return _columnTypeName[column - 1];
    }
    
    public java.lang.String getColumnTypeNameByIndex(int column) throws java.sql.SQLException {
        return _columnTypeName[column ];
    }

    public java.lang.String getColumnClassName(int column) throws java.sql.SQLException {
        if (_columnClassName == null) {
            // java.sql.ResultSetMetaData.getColumnClassName(int col) requires a JDBC 2 compliant database driver.
            throw new java.sql.SQLException(_sqlReason, _sqlState, _sqlVendorCode);
        }
        return _columnClassName[column - 1];
    }
    public java.lang.String getColumnClassNameByIndex(int column) throws java.sql.SQLException {
        if (_columnClassName == null) {
            // java.sql.ResultSetMetaData.getColumnClassName(int col) requires a JDBC 2 compliant database driver.
            throw new java.sql.SQLException(_sqlReason, _sqlState, _sqlVendorCode);
        }
        return _columnClassName[column];
    }

    public int getScale(int column) throws java.sql.SQLException {
//        return resultSetMetaData.getScale(column);
        return -1;
    }
    
    public int getScaleByIndex(int column) throws java.sql.SQLException {
//        return _scale[column ];
//        return resultSetMetaData.getScale(column+1);
        return -1;
    }

    public java.lang.String getColumnLabel(int column) throws java.sql.SQLException {
        return _columnLabel[column - 1];
    }
    
    public java.lang.String getColumnLabelByIndex(int column) throws java.sql.SQLException {
        return _columnLabel[column  ];
    }
    
    public java.lang.String getColumnLabelUpper(int column) {
//        if(columnLableUpperCase) {
            return _columnLabel_upper[column - 1];
//        }
//        else{
//            return _columnLabel[column - 1].toUpperCase();
//        }
    }
    
    public java.lang.String getColumnLabelUpperByIndex(int column) {
//        if(columnLableUpperCase) {
            return _columnLabel_upper[column ];
//        }
//        else{
//            return _columnLabel[column].toUpperCase();
//        }
    }

    public java.lang.String getColumnLabelLower(int column) {
        return _columnLabel[column - 1].toLowerCase();
    }

    public java.lang.String getColumnLabelLowerByIndex(int column) {
        return _columnLabel[column ].toLowerCase();
    }
    
    public java.lang.String getColumnJavaName(int column) {
        return this.columnJavaName[column - 1];
    }
    
    public java.lang.String getColumnJavaNameByIndex(int column) {
        return this.columnJavaName[column ];
    }

    public boolean isAutoIncrement(int column) throws java.sql.SQLException {
//        return _autoIncrement[column - 1];
        return false;
    }
    
    public boolean isAutoIncrementByIndex(int column) throws java.sql.SQLException {
//        return _autoIncrement[column ];
        return false;
    }

    public int getColumnDisplaySize(int column) throws java.sql.SQLException {
//        return _columnDisplaySize[column - 1];
        return -1;
    }
    public int getColumnDisplaySizeByIndex(int column) throws java.sql.SQLException {
//        return _columnDisplaySize[column];
        return -1;
    }

    public java.lang.String getCatalogName(int column) throws java.sql.SQLException {
//        return _catalogName[column - 1];
        return "";
    }
    
    public java.lang.String getCatalogNameByIndex(int column) throws java.sql.SQLException {
//        return _catalogName[column];
        return "";
    }

    public java.lang.String getColumnName(int column) throws java.sql.SQLException {
        return _columnName[column - 1];
    }
    
    public java.lang.String getColumnNameByIndex(int column) throws java.sql.SQLException {
        return _columnName[column ];
    }

    public boolean isWritable(int column) throws java.sql.SQLException {
//        return _writable[column - 1];
        return false;
    }
    
    public boolean isWritableByIndex(int column) throws java.sql.SQLException {
//        return _writable[column ];
        return false;
    }

    public boolean isSearchable(int column) throws java.sql.SQLException {
//        return _searchable[column - 1];
        return false;
    }
    
    public boolean isSearchableByIndex(int column) throws java.sql.SQLException {
//        return _searchable[column];
        return false;
    }

    public int getColumnType(int column) throws java.sql.SQLException {
        return _columnType[column - 1];
    }
    
    public int getColumnTypeByIndex(int column) throws java.sql.SQLException {
        return _columnType[column ];
    }

    public boolean isCurrency(int column) throws java.sql.SQLException {
//        return _currency[column - 1];
        return false;
    }
    
    public boolean isCurrencyByIndex(int column) throws java.sql.SQLException {
//        return _currency[column ];
        return false;
    }

    public java.lang.String getTableName(int column) throws java.sql.SQLException {
//        return _tableName[column - 1];
        return "";
    }
    public java.lang.String getTableNameByIndex(int column) throws java.sql.SQLException {
//        return _tableName[column ];
        return "";
    }

    public int isNullable(int column) throws java.sql.SQLException {
//        return _nullable[column - 1];
        return -1;
    }
    
    public int isNullableByIndex(int column) throws java.sql.SQLException {
//        return _nullable[column];
        return -1;
    }

    public boolean isSigned(int column) throws java.sql.SQLException {
//        return _signed[column - 1];
        return false;
    }
    public boolean isSignedByIndex(int column) throws java.sql.SQLException {
//        return _signed[column ];
        return false
                ;
    }

    public boolean isReadOnly(int column) throws java.sql.SQLException {
//        return _readOnly[column - 1];
        return false;
    }
    public boolean isReadOnlyByIndex(int column) throws java.sql.SQLException {
//        return _readOnly[column ];
        return false;
    }

    public boolean isDefinitelyWritable(int column) throws java.sql.SQLException {
//        return _definitelyWritable[column - 1];
        return false;
    }
    
    public boolean isDefinitelyWritableByIndex(int column) throws java.sql.SQLException {
//        return _definitelyWritable[column ];
        return false;
    }

    public int getPrecision(int column) throws java.sql.SQLException {
//        return _precision[column - 1];
        return -1;
    }
    
    public int getPrecisionByIndex(int column) throws java.sql.SQLException {
//        return _precision[column ];
        return -1;
    }

    public java.lang.String getSchemaName(int column) throws java.sql.SQLException {
//        return _schemaName[column - 1];
        return null;
    }
    
    public java.lang.String getSchemaNameByIndex(int column) throws java.sql.SQLException {
//        return _schemaName[column ];
        return null;
    }

    public boolean isCaseSensitive(int column) throws java.sql.SQLException {
//        return _caseSensitive[column - 1];
        return false;
    }
    public boolean isCaseSensitiveByIndex(int column) throws java.sql.SQLException {
//        return _caseSensitive[column ];
        return false;
    }

	public String[] get_columnLabel_upper() {
		return _columnLabel_upper;
	}
	
	public String toString()
	{
	    
	    if(this._columnLabel == null || this._columnLabel.length == 0)
	        return "";
	    StringBuilder ret = new StringBuilder();
	    boolean flag = false;
	    for(String name :this._columnLabel)
	    {
	        if(!flag)
	        {
	            ret.append(name);
	            flag = true;
	        }
	        else
	        {
	            ret.append(",").append(name);
	        }
	    }
	    return ret.toString();
	    
	}
	
	public String toDetailString()
	{
	    if(this._columnLabel == null || this._columnLabel.length == 0)
            return "";
        StringBuilder ret = new StringBuilder();
//        boolean flag = false;
        int i = 0;
        for(String name :this._columnLabel)
        {
            
            if(i == 0)
            {
                ret.append("columnname=").append(name).append("||").append("sqltype=").append(this._columnTypeName[i]).append("||javatype=").append(this._columnClassName[i]);
                
            }
            else
            {
                ret.append("\r\ncolumnname=").append(name).append("||").append("sqltype=").append(this._columnTypeName[i]).append("||javatype=").append(this._columnClassName[i]);
            }
            i ++;
        }
        return ret.toString();
	}
	public int seekIndex(String colName)
    {
//        if(columnLableUpperCase) {
            String temp = colName.toUpperCase();
            for (int i = 0; i < _columnLabel_upper.length; i++) {
                if (_columnLabel_upper[i].equals(temp))
                    return i;
            }
//        }
//        else{
//            for (int i = 0; i < _columnLabel.length; i++) {
//                if (_columnLabel[i].equals(colName))
//                    return i;
//            }
//        }
        throw new RowHandlerException("查询结果中不存在列[" + colName + "].");
    }
	
	/**列名获取列的信息开始
	 * @throws SQLException */
	public String getCatalogName(String colName) throws SQLException
	{
		return this.getCatalogNameByIndex(this.seekIndex(colName));
	}
	public String getColumnClassName(String colName) throws SQLException
	{
		return this.getColumnClassNameByIndex(this.seekIndex(colName));
	}
	public int getColumnDisplaySize(String colName) throws SQLException{
		return this.getColumnDisplaySizeByIndex(this.seekIndex(colName) );
	}
	public String getColumnLabel(String colName) throws SQLException{
		return this.getColumnLabelByIndex(this.seekIndex(colName) );
	}
	public String getColumnLabelUpper(String colName) throws SQLException{
		return this.getColumnLabelUpperByIndex(this.seekIndex(colName) );
	}
	public String getColumnName(String colName) throws SQLException{
		return this.getColumnNameByIndex(this.seekIndex(colName) );
	}
	public int getColumnType(String colName) throws SQLException{
		return this.getColumnTypeByIndex(this.seekIndex(colName) );
	}
	public String getColumnTypeName(String colName) throws SQLException{
		return this.getColumnTypeNameByIndex(this.seekIndex(colName) );
	}
	
	public int getPrecision(String colName) throws SQLException{
		return this.getPrecisionByIndex(this.seekIndex(colName) );
	}
	public int getScale(String colName) throws SQLException{
		return this.getScaleByIndex(this.seekIndex(colName) );
	}
	public String getSchemaName(String colName) throws SQLException{
		return this.getSchemaNameByIndex(this.seekIndex(colName) );
	}
	public String getTableName(String colName) throws SQLException{
		return this.getTableNameByIndex(this.seekIndex(colName) );
	}
	public boolean isAutoIncrement(String colName) throws SQLException{
		return this.isAutoIncrementByIndex(this.seekIndex(colName) );
	}
	public boolean isCaseSensitive(String colName) throws SQLException{
		return this.isCaseSensitiveByIndex(this.seekIndex(colName) );
	}
	public boolean isCurrency(String colName) throws SQLException{
		return this.isCurrencyByIndex(this.seekIndex(colName) );
	}
	public boolean isDefinitelyWritable(String colName) throws SQLException{
		return this.isDefinitelyWritableByIndex(this.seekIndex(colName) );
	}
	public int isNullable(String colName) throws SQLException{
		return this.isNullableByIndex(this.seekIndex(colName) );
	}
	public boolean isReadOnly(String colName) throws SQLException{
		return this.isReadOnlyByIndex(this.seekIndex(colName) );
	}
	public boolean isSearchable(String colName) throws SQLException{
		return this.isSearchableByIndex(this.seekIndex(colName) );
	}
	public boolean isSigned(String colName) throws SQLException{
		return this.isSignedByIndex(this.seekIndex(colName) );
	}
	public boolean isWritable(String colName) throws SQLException{
		return this.isWritableByIndex(this.seekIndex(colName) );
	}
	public  T unwrap(Class iface) throws SQLException {
		// TODO Auto-generated method stub
		return null;
	}
	public boolean isWrapperFor(Class iface) throws SQLException {
		// TODO Auto-generated method stub
		return false;
	}
	public String[] getColumnJavaName() {
		return columnJavaName;
	}
	public String[] get_columnLabel() {
		return _columnLabel;
	}
	public int[] get_columnType() {
		return _columnType;
	}
//    public String[] getColumnLabelLower(){
//        return _columnLabel_lower;
//    }
}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy