亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ssresultsetmetadata.java

?? 這是一個油Java實作的資料庫系統 是個入門的好材料
?? JAVA
字號:
/* =============================================================
 * SmallSQL : a free Java DBMS library for the Java(tm) platform
 * =============================================================
 *
 * (C) Copyright 2004-2007, by Volker Berlin.
 *
 * Project Info:  http://www.smallsql.de/
 *
 * This library is free software; you can redistribute it and/or modify it 
 * under the terms of the GNU Lesser General Public License as published by 
 * the Free Software Foundation; either version 2.1 of the License, or 
 * (at your option) any later version.
 *
 * This library 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 GNU Lesser General Public 
 * License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, 
 * USA.  
 *
 * [Java is a trademark or registered trademark of Sun Microsystems, Inc. 
 * in the United States and other countries.]
 *
 * ---------------
 * SSResultSetMetaData.java
 * ---------------
 * Author: Volker Berlin
 * 
 */
package smallsql.database;

import java.sql.*;

import smallsql.database.language.Language;


public class SSResultSetMetaData implements ResultSetMetaData {

    Expressions columns;

    public int getColumnCount() throws SQLException {
        return columns.size();
    }
    
    
    public boolean isAutoIncrement(int column) throws SQLException {
        return getColumnExpression( column ).isAutoIncrement();
    }
    
    
    public boolean isCaseSensitive(int column) throws SQLException {
        return getColumnExpression( column ).isCaseSensitive();
    }
    
    
    public boolean isSearchable(int column) throws SQLException {
    	int type = getColumnExpression( column ).getType();
        return type == Expression.NAME || type == Expression.FUNCTION;
    }
    
    
    public boolean isCurrency(int column) throws SQLException {
        switch(getColumnExpression( column ).getDataType()){
            case SQLTokenizer.MONEY:
            case SQLTokenizer.SMALLMONEY:
                return true;
        }
        return false;
    }
    
    
    public int isNullable(int column) throws SQLException {
        return getColumnExpression( column ).isNullable() ? columnNullable : columnNoNulls;
    }
    
    
    public boolean isSigned(int column) throws SQLException {
		return isSignedDataType(getColumnExpression( column ).getDataType());
    }
    
    
	static boolean isSignedDataType(int dataType) {
		switch(dataType){
			case SQLTokenizer.SMALLINT:
			case SQLTokenizer.INT:
			case SQLTokenizer.BIGINT:
			case SQLTokenizer.SMALLMONEY:
			case SQLTokenizer.MONEY:
			case SQLTokenizer.DECIMAL:
			case SQLTokenizer.NUMERIC:
			case SQLTokenizer.REAL:
			case SQLTokenizer.FLOAT:
			case SQLTokenizer.DOUBLE:
				return true;
		}
		return false;
	}
	
    
	static boolean isNumberDataType(int dataType) {
		return isSignedDataType(dataType) || dataType == SQLTokenizer.TINYINT;
	}
	
    
	static boolean isBinaryDataType(int dataType) {
		switch(dataType){
			case SQLTokenizer.BINARY:
			case SQLTokenizer.VARBINARY:
			case SQLTokenizer.LONGVARBINARY:
			case SQLTokenizer.BLOB:
				return true;
		}
		return false;
	}
	
	
	static int getDisplaySize(int dataType, int precision, int scale){
		switch(dataType){
			case SQLTokenizer.BIT:
				return 1; // 1 and 0
			case SQLTokenizer.BOOLEAN:
				return 5; //true and false
			case SQLTokenizer.TINYINT:
				return 3;
			case SQLTokenizer.SMALLINT:
				return 6;
			case SQLTokenizer.INT:
				return 10;
			case SQLTokenizer.BIGINT:
            case SQLTokenizer.MONEY:
				return 19;
            case SQLTokenizer.REAL:
                return 13;
			case SQLTokenizer.FLOAT:
			case SQLTokenizer.DOUBLE:
				return 17;
			case SQLTokenizer.LONGVARCHAR:
            case SQLTokenizer.LONGNVARCHAR:
			case SQLTokenizer.LONGVARBINARY:
            case SQLTokenizer.JAVA_OBJECT:
            case SQLTokenizer.BLOB:
            case SQLTokenizer.CLOB:
            case SQLTokenizer.NCLOB:
				return Integer.MAX_VALUE;
			case SQLTokenizer.NUMERIC:
				return precision + (scale>0 ? 2 : 1);
			case SQLTokenizer.VARBINARY:
			case SQLTokenizer.BINARY:
				return 2 + precision*2;
            case SQLTokenizer.SMALLDATETIME:
                return 21;
			default:
				return precision;
		}
	}
	
    
	static int getDataTypePrecision(int dataType, int defaultValue){
		switch(dataType){
			case SQLTokenizer.NULL:
				return 0;
			case SQLTokenizer.BIT:
			case SQLTokenizer.BOOLEAN:
				return 1;
			case SQLTokenizer.TINYINT:
				return 3;
			case SQLTokenizer.SMALLINT:
				return 5;
			case SQLTokenizer.INT:
			case SQLTokenizer.SMALLMONEY:
				return 10;
			case SQLTokenizer.BIGINT:
			case SQLTokenizer.MONEY:
				return 19;
			case SQLTokenizer.REAL:
				return 7;
			case SQLTokenizer.FLOAT:
			case SQLTokenizer.DOUBLE:
				return 15;
            case SQLTokenizer.CHAR:
            case SQLTokenizer.NCHAR:
			case SQLTokenizer.VARCHAR:
            case SQLTokenizer.NVARCHAR:
            case SQLTokenizer.BINARY:
			case SQLTokenizer.VARBINARY:
				if(defaultValue == -1)
					return 0xFFFF;
                return defaultValue;
			case SQLTokenizer.NUMERIC:
			case SQLTokenizer.DECIMAL:
                if(defaultValue == -1)
                    return 38;
                return defaultValue;
			case SQLTokenizer.TIMESTAMP:
				return 23;
			case SQLTokenizer.TIME:
				return 8;
			case SQLTokenizer.DATE:
				return 10;
			case SQLTokenizer.SMALLDATETIME:
				return 16;
			case SQLTokenizer.UNIQUEIDENTIFIER:
				return 36;
			case SQLTokenizer.LONGVARCHAR:
            case SQLTokenizer.LONGNVARCHAR:
			case SQLTokenizer.LONGVARBINARY:
				return Integer.MAX_VALUE;
		}
		if(defaultValue == -1)
			throw new Error("Precision:"+SQLTokenizer.getKeyWord(dataType));
		return defaultValue;
	}
	
	
    public int getColumnDisplaySize(int column) throws SQLException {
        return getColumnExpression( column ).getDisplaySize();
    }
    public String getColumnLabel(int column) throws SQLException {
        return getColumnExpression( column ).getAlias();
    }
    public String getColumnName(int column) throws SQLException {
        return getColumnExpression( column ).getAlias();
    }
    public String getSchemaName(int column) throws SQLException {
        return null;
    }
    public int getPrecision(int column) throws SQLException {
        return getColumnExpression( column ).getPrecision();
    }
    public int getScale(int column) throws SQLException {
        return getColumnExpression( column ).getScale();
    }
    public String getTableName(int column) throws SQLException {
        return getColumnExpression( column ).getTableName();
    }
    public String getCatalogName(int column) throws SQLException {
        return null;
    }
    public int getColumnType(int column) throws SQLException {
        return SQLTokenizer.getSQLDataType(getColumnExpression( column ).getDataType() );
    }
    public String getColumnTypeName(int column) throws SQLException {
        return SQLTokenizer.getKeyWord( getColumnExpression( column ).getDataType() );
    }
    public boolean isReadOnly(int column) throws SQLException {
        return !getColumnExpression( column ).isDefinitelyWritable();
    }
    public boolean isWritable(int column) throws SQLException {
        return getColumnExpression( column ).isDefinitelyWritable();
    }
    public boolean isDefinitelyWritable(int column) throws SQLException {
        return getColumnExpression( column ).isDefinitelyWritable();
    }
    public String getColumnClassName(int column) throws SQLException {
        switch(getColumnType(column)){
            case Types.TINYINT:
            case Types.SMALLINT:
            case Types.INTEGER:
                    return "java.lang.Integer";
            case Types.BIT:
            case Types.BOOLEAN:
                    return "java.lang.Boolean";
            case Types.BINARY:
            case Types.VARBINARY:
            case Types.LONGVARBINARY:
                    return "[B";
            case Types.BLOB:
                    return "java.sql.Blob";
            case Types.BIGINT:
                    return "java.lang.Long";
            case Types.DECIMAL:
            case Types.NUMERIC:
                    return "java.math.BigDecimal";
            case Types.REAL:
                    return "java.lang.Float";
            case Types.FLOAT:
            case Types.DOUBLE:
                    return "java.lang.Double";
            case Types.DATE:
                    return "java.sql.Date";
            case Types.TIME:
                    return "java.sql.Time";
            case Types.TIMESTAMP:
                    return "java.sql.Timestamp";
            case Types.CHAR:
            case Types.VARCHAR:
            case Types.LONGVARCHAR:
            case -11: //uniqueidentifier
                    return "java.lang.String";
            case Types.CLOB:
                    return "java.sql.Clob";
            default: return "java.lang.Object";
        }
    }

/*========================================================

private methods

=========================================================*/

	final int getColumnIdx( int column ) throws SQLException{
		if(column < 1 || column > columns.size())
			throw SmallSQLException.create( Language.COL_IDX_OUT_RANGE, String.valueOf(column));
		return column-1;
	}

    final Expression getColumnExpression( int column ) throws SQLException{
        return columns.get( getColumnIdx( column ) );
    }


}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99精品视频中文字幕| 美女脱光内衣内裤视频久久网站| 欧美二区在线观看| 成人av网站在线观看免费| 精品一区二区在线播放| 美国三级日本三级久久99| 青娱乐精品视频| 免费成人性网站| 久久99久久99| 大尺度一区二区| 高清日韩电视剧大全免费| 丰满岳乱妇一区二区三区| 国产久卡久卡久卡久卡视频精品| 国产一区二区三区免费在线观看 | 国产视频一区二区在线| 91麻豆精品国产91久久久久久| 欧美性大战久久| 色综合天天做天天爱| 欧美在线播放高清精品| 欧美午夜宅男影院| 精品国产一区二区三区久久久蜜月 | 中文字幕在线视频一区| 亚洲人成精品久久久久| 亚洲动漫第一页| 韩国午夜理伦三级不卡影院| 福利电影一区二区| 色综合久久99| 日韩欧美成人激情| 中文字幕在线不卡一区二区三区| 亚洲综合一区二区| 精品一区二区三区的国产在线播放| 国产精品一二三| 欧美三级在线看| 久久九九影视网| 亚洲一区二区视频在线观看| 国产在线播放一区二区三区| 91网页版在线| 久久欧美一区二区| 亚洲成人tv网| 99天天综合性| 精品1区2区在线观看| 中文字幕日韩av资源站| 毛片基地黄久久久久久天堂| jvid福利写真一区二区三区| 欧美一区二区免费| 夜色激情一区二区| 国产成人午夜精品影院观看视频 | 99久久精品国产麻豆演员表| 欧美麻豆精品久久久久久| 久久久久久久久久久久久女国产乱 | 国产精品拍天天在线| 五月婷婷综合网| 色综合久久久久久久久久久| 精品国产凹凸成av人网站| 天堂va蜜桃一区二区三区漫画版| 成人免费视频视频| 久久综合成人精品亚洲另类欧美| 性做久久久久久免费观看| 91在线免费播放| 国产精品美女久久久久久久网站| 精品一区二区三区免费视频| 欧美精品在线观看播放| 亚洲欧洲av色图| 国产91精品一区二区麻豆网站| 精品久久人人做人人爱| 性久久久久久久久久久久| 在线视频综合导航| 亚洲欧美一区二区久久| 成人av在线看| 国产精品久久久久久久久免费丝袜| 日韩不卡免费视频| 欧美日韩不卡一区二区| 午夜欧美大尺度福利影院在线看| 在线免费观看日本一区| 亚洲影院久久精品| 欧美色区777第一页| 亚洲成人免费在线观看| 在线观看网站黄不卡| 一区二区三区精品视频在线| 色婷婷亚洲综合| 亚洲永久精品大片| 在线播放91灌醉迷j高跟美女 | 精品少妇一区二区三区在线播放| 日韩国产高清在线| 日韩欧美在线123| 韩国午夜理伦三级不卡影院| 久久女同性恋中文字幕| 成人激情黄色小说| 亚洲激情在线激情| 欧美日韩一区二区在线观看视频| 亚洲电影第三页| 日韩欧美视频在线| 国产成人av福利| 亚洲综合色区另类av| 91精品婷婷国产综合久久竹菊| 免费观看在线色综合| 久久久久国产精品麻豆| 99久久精品国产一区二区三区| 亚洲人精品一区| 678五月天丁香亚洲综合网| 久久精品国产亚洲高清剧情介绍| 国产偷v国产偷v亚洲高清| 91看片淫黄大片一级在线观看| 亚洲午夜国产一区99re久久| 欧美xxxxxxxx| 99国产精品一区| 另类欧美日韩国产在线| 国产精品久久久一本精品| 在线观看91av| 99久久伊人久久99| 老鸭窝一区二区久久精品| 中文字幕av资源一区| 9191精品国产综合久久久久久| 国产福利一区二区| 午夜电影一区二区| 国产精品沙发午睡系列990531| 欧美三级一区二区| 成人午夜免费av| 美日韩一区二区| 亚洲一区二区三区自拍| 国产午夜精品久久久久久久 | 欧美精品v国产精品v日韩精品 | 国产乱一区二区| 亚洲一级不卡视频| 国产精品亲子伦对白| 日韩美一区二区三区| 91网站在线观看视频| 黄页视频在线91| 五月婷婷综合激情| 亚洲尤物视频在线| 中文字幕欧美一| 久久婷婷一区二区三区| 7777精品伊人久久久大香线蕉| 99vv1com这只有精品| 国产福利一区在线观看| 美腿丝袜亚洲色图| 老司机午夜精品99久久| 亚洲成人免费在线观看| 亚洲国产综合视频在线观看| 国产精品青草综合久久久久99| 精品国产一区a| 日韩欧美国产一区二区三区| 欧美三区在线观看| 在线观看亚洲精品| 欧美系列在线观看| 欧美三片在线视频观看| 欧美午夜精品久久久| 91在线播放网址| 91丝袜美女网| 91亚洲国产成人精品一区二三| 成人亚洲精品久久久久软件| 国产精品18久久久久久久久 | 国产aⅴ综合色| 国产精品99久久久久久宅男| 精品一二三四在线| 精品伊人久久久久7777人| 精品在线你懂的| 久久不见久久见免费视频1| 国产制服丝袜一区| 高清日韩电视剧大全免费| eeuss国产一区二区三区| 成人99免费视频| 欧美在线视频不卡| 91精品综合久久久久久| 欧美日韩亚洲综合在线| 884aa四虎影成人精品一区| 91精品国产一区二区三区| 日韩视频一区在线观看| 久久综合九色综合欧美98| 国产午夜精品福利| 亚洲人成精品久久久久久| 亚洲一区二区三区四区的| 日产精品久久久久久久性色| 久久99国产精品尤物| 不卡的电视剧免费网站有什么| 色菇凉天天综合网| 日韩午夜激情电影| 中文字幕第一区综合| 一区二区三区国产| 麻豆精品视频在线观看视频| 成人三级在线视频| 在线视频欧美精品| 欧美第一区第二区| 亚洲六月丁香色婷婷综合久久| 日韩1区2区日韩1区2区| 成人午夜电影网站| 欧美电影在线免费观看| 欧美经典一区二区三区| 亚洲va国产天堂va久久en| 国产毛片一区二区| 欧美人狂配大交3d怪物一区| 欧美精品一区二区三区在线播放| 亚洲色图在线看| 国产麻豆欧美日韩一区| 欧美性一级生活| 中文字幕日韩欧美一区二区三区| 日本成人在线网站| 在线欧美日韩精品| 中文字幕av资源一区| 久久综合综合久久综合|