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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? databasemetadata.java

?? mysql jdbc驅(qū)動(dòng)程序 mysql jdbc驅(qū)動(dòng)程序 mysql jdbc驅(qū)動(dòng)程序 mysql jdbc驅(qū)動(dòng)程序
?? JAVA
?? 第 1 頁 / 共 5 頁
字號:
		fields[3] = new Field("", "ATTR_NAME", Types.CHAR, 32);		fields[4] = new Field("", "DATA_TYPE", Types.SMALLINT, 32);		fields[5] = new Field("", "ATTR_TYPE_NAME", Types.CHAR, 32);		fields[6] = new Field("", "ATTR_SIZE", Types.INTEGER, 32);		fields[7] = new Field("", "DECIMAL_DIGITS", Types.INTEGER, 32);		fields[8] = new Field("", "NUM_PREC_RADIX", Types.INTEGER, 32);		fields[9] = new Field("", "NULLABLE ", Types.INTEGER, 32);		fields[10] = new Field("", "REMARKS", Types.CHAR, 32);		fields[11] = new Field("", "ATTR_DEF", Types.CHAR, 32);		fields[12] = new Field("", "SQL_DATA_TYPE", Types.INTEGER, 32);		fields[13] = new Field("", "SQL_DATETIME_SUB", Types.INTEGER, 32);		fields[14] = new Field("", "CHAR_OCTET_LENGTH", Types.INTEGER, 32);		fields[15] = new Field("", "ORDINAL_POSITION", Types.INTEGER, 32);		fields[16] = new Field("", "IS_NULLABLE", Types.CHAR, 32);		fields[17] = new Field("", "SCOPE_CATALOG", Types.CHAR, 32);		fields[18] = new Field("", "SCOPE_SCHEMA", Types.CHAR, 32);		fields[19] = new Field("", "SCOPE_TABLE", Types.CHAR, 32);		fields[20] = new Field("", "SOURCE_DATA_TYPE", Types.SMALLINT, 32);		return buildResultSet(fields, new ArrayList());	}	/**	 * Get a description of a table's optimal set of columns that uniquely	 * identifies a row. They are ordered by SCOPE.	 * <P>	 * Each column description has the following columns:	 * <OL>	 * <li> <B>SCOPE</B> short => actual scope of result	 * <UL>	 * <li> bestRowTemporary - very temporary, while using row </li>	 * <li> bestRowTransaction - valid for remainder of current transaction	 * </li>	 * <li> bestRowSession - valid for remainder of current session </li>	 * </ul>	 * </li>	 * <li> <B>COLUMN_NAME</B> String => column name </li>	 * <li> <B>DATA_TYPE</B> short => SQL data type from java.sql.Types </li>	 * <li> <B>TYPE_NAME</B> String => Data source dependent type name </li>	 * <li> <B>COLUMN_SIZE</B> int => precision </li>	 * <li> <B>BUFFER_LENGTH</B> int => not used </li>	 * <li> <B>DECIMAL_DIGITS</B> short => scale </li>	 * <li> <B>PSEUDO_COLUMN</B> short => is this a pseudo column like an	 * Oracle ROWID	 * <UL>	 * <li> bestRowUnknown - may or may not be pseudo column </li>	 * <li> bestRowNotPseudo - is NOT a pseudo column </li>	 * <li> bestRowPseudo - is a pseudo column </li>	 * </ul>	 * </li>	 * </ol>	 * </p>	 * 	 * @param catalog	 *            a catalog name; "" retrieves those without a catalog	 * @param schema	 *            a schema name; "" retrieves those without a schema	 * @param table	 *            a table name	 * @param scope	 *            the scope of interest; use same values as SCOPE	 * @param nullable	 *            include columns that are nullable?	 * @return ResultSet each row is a column description	 * @throws SQLException	 *             DOCUMENT ME!	 */	public java.sql.ResultSet getBestRowIdentifier(String catalog,			String schema, final String table, int scope, boolean nullable)			throws SQLException {		if (table == null) {			throw SQLError.createSQLException("Table not specified.",					SQLError.SQL_STATE_ILLEGAL_ARGUMENT);		}		Field[] fields = new Field[8];		fields[0] = new Field("", "SCOPE", Types.SMALLINT, 5);		fields[1] = new Field("", "COLUMN_NAME", Types.CHAR, 32);		fields[2] = new Field("", "DATA_TYPE", Types.SMALLINT, 32);		fields[3] = new Field("", "TYPE_NAME", Types.CHAR, 32);		fields[4] = new Field("", "COLUMN_SIZE", Types.INTEGER, 10);		fields[5] = new Field("", "BUFFER_LENGTH", Types.INTEGER, 10);		fields[6] = new Field("", "DECIMAL_DIGITS", Types.INTEGER, 10);		fields[7] = new Field("", "PSEUDO_COLUMN", Types.SMALLINT, 5);		final ArrayList rows = new ArrayList();		final Statement stmt = this.conn.getMetadataSafeStatement();		try {			new IterateBlock(getCatalogIterator(catalog)) {				void forEach(Object catalogStr) throws SQLException {					ResultSet results = null;					try {						StringBuffer queryBuf = new StringBuffer(								"SHOW COLUMNS FROM ");						queryBuf.append(quotedId);						queryBuf.append(table);						queryBuf.append(quotedId);						queryBuf.append(" FROM ");						queryBuf.append(quotedId);						queryBuf.append(catalogStr.toString());						queryBuf.append(quotedId);						results = stmt.executeQuery(queryBuf.toString());						while (results.next()) {							String keyType = results.getString("Key");							if (keyType != null) {								if (StringUtils.startsWithIgnoreCase(keyType,										"PRI")) {									byte[][] rowVal = new byte[8][];									rowVal[0] = Integer											.toString(													java.sql.DatabaseMetaData.bestRowSession)											.getBytes();									rowVal[1] = results.getBytes("Field");									String type = results.getString("Type");									int size = MysqlIO.getMaxBuf();									int decimals = 0;									/*									 * Parse the Type column from MySQL									 */									if (type.indexOf("enum") != -1) {										String temp = type.substring(type												.indexOf("("), type												.indexOf(")"));										java.util.StringTokenizer tokenizer = new java.util.StringTokenizer(												temp, ",");										int maxLength = 0;										while (tokenizer.hasMoreTokens()) {											maxLength = Math.max(maxLength,													(tokenizer.nextToken()															.length() - 2));										}										size = maxLength;										decimals = 0;										type = "enum";									} else if (type.indexOf("(") != -1) {										if (type.indexOf(",") != -1) {											size = Integer.parseInt(type													.substring(type															.indexOf("(") + 1,															type.indexOf(",")));											decimals = Integer.parseInt(type													.substring(type															.indexOf(",") + 1,															type.indexOf(")")));										} else {											size = Integer.parseInt(type													.substring(type															.indexOf("(") + 1,															type.indexOf(")")));										}										type = type.substring(0, type												.indexOf("("));									}									rowVal[2] = s2b(String.valueOf(MysqlDefs											.mysqlToJavaType(type)));									rowVal[3] = s2b(type);									rowVal[4] = Integer.toString(											size + decimals).getBytes();									rowVal[5] = Integer.toString(											size + decimals).getBytes();									rowVal[6] = Integer.toString(decimals)											.getBytes();									rowVal[7] = Integer											.toString(													java.sql.DatabaseMetaData.bestRowNotPseudo)											.getBytes();									rows.add(rowVal);								}							}						}					} finally {						if (results != null) {							try {								results.close();							} catch (Exception ex) {								;							}							results = null;						}					}				}			}.doForAll();		} finally {			if (stmt != null) {				stmt.close();			}		}		java.sql.ResultSet results = buildResultSet(fields, rows);		return results;	}	/*	 * * Each row in the ResultSet is a parameter desription or column	 * description with the following fields: <OL> <li> <B>PROCEDURE_CAT</B>	 * String => procedure catalog (may be null) </li> <li> <B>PROCEDURE_SCHEM</B>	 * String => procedure schema (may be null) </li> <li> <B>PROCEDURE_NAME</B>	 * String => procedure name </li> <li> <B>COLUMN_NAME</B> String =>	 * column/parameter name </li> <li> <B>COLUMN_TYPE</B> Short => kind of	 * column/parameter: <UL> <li> procedureColumnUnknown - nobody knows </li>	 * <li> procedureColumnIn - IN parameter </li> <li> procedureColumnInOut -	 * INOUT parameter </li> <li> procedureColumnOut - OUT parameter </li> <li>	 * procedureColumnReturn - procedure return value </li> <li>	 * procedureColumnResult - result column in ResultSet </li> </ul> </li> <li>	 * <B>DATA_TYPE</B> short => SQL type from java.sql.Types </li> <li>	 * <B>TYPE_NAME</B> String => SQL type name </li> <li> <B>PRECISION</B>	 * int => precision </li> <li> <B>LENGTH</B> int => length in bytes of data	 * </li> <li> <B>SCALE</B> short => scale </li> <li> <B>RADIX</B> short =>	 * radix </li> <li> <B>NULLABLE</B> short => can it contain NULL? <UL> <li>	 * procedureNoNulls - does not allow NULL values </li> <li>	 * procedureNullable - allows NULL values </li> <li>	 * procedureNullableUnknown - nullability unknown </li> </ul> </li> <li>	 * <B>REMARKS</B> String => comment describing parameter/column </li> </ol>	 * </p> <P> <B>Note:</B> Some databases may not return the column	 * descriptions for a procedure. Additional columns beyond REMARKS can be	 * defined by the database. </p> @param catalog a catalog name; "" retrieves	 * those without a catalog @param schemaPattern a schema name pattern; ""	 * retrieves those without a schema @param procedureNamePattern a procedure	 * name pattern @param columnNamePattern a column name pattern @return	 * ResultSet each row is a stored procedure parameter or column description	 * @throws SQLException if a database access error occurs	 * 	 * @see #getSearchStringEscape	 */	private void getCallStmtParameterTypes(String catalog, String procName,			String parameterNamePattern, List resultRows) throws SQLException {		java.sql.Statement paramRetrievalStmt = null;		java.sql.ResultSet paramRetrievalRs = null;		if (parameterNamePattern == null) {			if (this.conn.getNullNamePatternMatchesAll()) {				parameterNamePattern = "%";			} else {				throw SQLError						.createSQLException(								"Parameter/Column name pattern can not be NULL or empty.",								SQLError.SQL_STATE_ILLEGAL_ARGUMENT);			}		}		byte[] procNameAsBytes = null;		try {			procNameAsBytes = procName.getBytes("UTF-8");		} catch (UnsupportedEncodingException ueEx) {			procNameAsBytes = s2b(procName);		}		String quoteChar = getIdentifierQuoteString();		String parameterDef = null;		boolean isProcedureInAnsiMode = false;		String storageDefnDelims = null;		String storageDefnClosures = null;				try {			paramRetrievalStmt = this.conn.getMetadataSafeStatement();			if (this.conn.lowerCaseTableNames() && catalog != null					&& catalog.length() != 0) {				// Workaround for bug in server wrt. to				// SHOW CREATE PROCEDURE not respecting				// lower-case table names				String oldCatalog = this.conn.getCatalog();				ResultSet rs = null;				try {					this.conn.setCatalog(catalog);					rs = paramRetrievalStmt.executeQuery("SELECT DATABASE()");					rs.next();					catalog = rs.getString(1);				} finally {					this.conn.setCatalog(oldCatalog);					if (rs != null) {						rs.close();					}				}			}			if (paramRetrievalStmt.getMaxRows() != 0) {				paramRetrievalStmt.setMaxRows(0);			}			int dotIndex = -1;			if (!" ".equals(quoteChar)) {				dotIndex = StringUtils.indexOfIgnoreCaseRespectQuotes(0,						procName, ".", quoteChar.charAt(0), !this.conn								.isNoBackslashEscapesSet());			} else {				dotIndex = procName.indexOf(".");			}			String dbName = null;			if (dotIndex != -1 && (dotIndex + 1) < procName.length()) {				dbName = procName.substring(0, dotIndex);				procName = procName.substring(dotIndex + 1);			} else {				dbName = catalog;			}			StringBuffer procNameBuf = new StringBuffer();			if (dbName != null) {				if (!" ".equals(quoteChar) && !dbName.startsWith(quoteChar)) {					procNameBuf.append(quoteChar);				}				procNameBuf.append(dbName);				if (!" ".equals(quoteChar) && !dbName.startsWith(quoteChar)) {					procNameBuf.append(quoteChar);				}				procNameBuf.append(".");			}			boolean procNameIsNotQuoted = !procName.startsWith(quoteChar);			if (!" ".equals(quoteChar) && procNameIsNotQuoted) {				procNameBuf.append(quoteChar);			}			procNameBuf.append(procName);			if (!" ".equals(quoteChar) && procNameIsNotQuoted) {				procNameBuf.append(quoteChar);			}			boolean parsingFunction = false;			try {				paramRetrievalRs = paramRetrievalStmt						.executeQuery("SHOW CREATE PROCEDURE "								+ procNameBuf.toString());				parsingFunction = false;			} catch (SQLException sqlEx) {				paramRetrievalRs = paramRetrievalStmt						.executeQuery("SHOW CREATE FUNCTION "								+ procNameBuf.toString());				parsingFunction = true;			}			if (paramRetrievalRs.next()) {				String procedureDef = parsingFunction ? paramRetrievalRs						.getString("Create Function") : paramRetrievalRs						.getString("Create Procedure");				if (procedureDef == null || procedureDef.length() == 0) {					throw SQLError							.createSQLException(									"User does not have access to metadata required to determine "											+ "stored procedure parameter types. If rights can not be granted, configure connection with \"noAccessToProcedureBodies=true\" "											+ "to have driver generate parameters that represent INOUT strings irregardless of actual parameter types.",									SQLError.SQL_STATE_GENERAL_ERROR);				}				try {					String sqlMode = paramRetrievalRs.getString("sql_mode");										if (StringUtils.indexOfIgnoreCase(sqlMode, "ANSI") != -1) {						isProcedureInAnsiMode = true;					}				} catch (SQLException sqlEx) {					// doesn't exist				}				String identifierMarkers = isProcedureInAnsiMode ? "`\"" : "`";				String identifierAndStringMarkers = "'" + identifierMarkers;				storageDefnDelims = "(" + identifierMarkers;				storageDefnClosures = ")" + identifierMarkers;								// sanitize/normalize by stripping out comments				procedureDef = StringUtils.stripComments(procedureDef, 						identifierAndStringMarkers, identifierAndStringMarkers, true, false, true, true);								int openParenIndex = StringUtils						.indexOfIgnoreCaseRespectQuotes(0, procedureDef, "(",								quoteChar.charAt(0), !this.conn										.isNoBackslashEscapesSet());				int endOfParamDeclarationIndex = 0;				endOfParamDeclarationIndex = endPositionOfParameterDeclaration(						openParenIndex, procedureDef, quoteChar);				if (parsingFunction) {					// Grab the return column since it needs					// to go first in the output result set					int returnsIndex = StringUtils							.indexOfIgnoreCaseRespectQuotes(0, procedureDef,

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产午夜精品久久久久久久| 国产91丝袜在线播放0| 在线观看91精品国产入口| 国产精品久久三| 国产99精品国产| 中文字幕不卡一区| 成人av在线资源网| 一区二区三区资源| 欧美精品vⅰdeose4hd| 日韩不卡在线观看日韩不卡视频| 51久久夜色精品国产麻豆| 日本视频免费一区| 国产香蕉久久精品综合网| www.一区二区| 亚洲成人自拍偷拍| 亚洲精品在线观看网站| 国产成人免费在线视频| 自拍偷拍欧美精品| 欧美日韩一区高清| 精品一区二区免费| 日韩一区中文字幕| 欧美一级在线观看| 成人激情文学综合网| 亚洲午夜久久久| 26uuu国产电影一区二区| av激情成人网| 热久久一区二区| 亚洲素人一区二区| 欧美一级专区免费大片| 成人高清视频免费观看| 亚洲成人动漫精品| 中文字幕国产一区| 91精品国产高清一区二区三区| 国产精品资源网站| 午夜精品一区二区三区免费视频| 久久看人人爽人人| 欧美性高清videossexo| 国产精品系列在线播放| 亚洲国产wwwccc36天堂| 久久精品视频免费| 91精品国产综合久久精品| 国产福利不卡视频| 日韩 欧美一区二区三区| 欧美激情中文字幕| 日韩欧美在线123| 欧美综合一区二区三区| 国产精品一二三在| 免费在线观看一区二区三区| 国产精品久久久一区麻豆最新章节| 91精品麻豆日日躁夜夜躁| 成人精品国产一区二区4080| 日本vs亚洲vs韩国一区三区 | 日韩欧美在线一区二区三区| 成人免费毛片a| 韩国女主播成人在线观看| 亚洲国产精品嫩草影院| 国产精品久久久久9999吃药| 日韩欧美高清dvd碟片| 欧美色涩在线第一页| 99热精品国产| 成熟亚洲日本毛茸茸凸凹| 日韩成人免费电影| 亚洲chinese男男1069| 日韩美女啊v在线免费观看| 久久久精品国产免费观看同学| 欧美一区二区播放| 91精品啪在线观看国产60岁| 欧美性欧美巨大黑白大战| 日本道色综合久久| 色八戒一区二区三区| 成人av影视在线观看| 国产一区二区在线看| 久久爱另类一区二区小说| 日韩高清不卡一区二区三区| 亚洲第四色夜色| 天堂久久久久va久久久久| 一区二区三区欧美日韩| 亚洲日本韩国一区| 樱桃视频在线观看一区| 亚洲男同性视频| 亚洲男同性恋视频| 亚洲一区中文日韩| 亚洲午夜精品在线| 日本在线不卡视频| 日本成人在线不卡视频| 青青青爽久久午夜综合久久午夜| 日韩精品欧美精品| 久草热8精品视频在线观看| 久久精品国产秦先生| 美女尤物国产一区| 国产乱码精品一区二区三区五月婷 | 国产精品视频免费| 国产精品嫩草久久久久| 国产精品麻豆视频| 亚洲精品乱码久久久久久| 一区二区三区**美女毛片| 一区av在线播放| 青青草97国产精品免费观看无弹窗版| 日韩成人av影视| 国产精品影视在线观看| 成人精品鲁一区一区二区| 91麻豆精东视频| 这里只有精品99re| 国产亚洲美州欧州综合国| 国产精品传媒在线| 性做久久久久久久免费看| 日本不卡高清视频| 成人激情开心网| 欧美日韩精品欧美日韩精品| 日韩欧美成人一区二区| 中国色在线观看另类| 亚洲综合激情另类小说区| 日韩专区欧美专区| 豆国产96在线|亚洲| 欧美熟乱第一页| 久久久国产一区二区三区四区小说| 国产精品高清亚洲| 日本成人在线视频网站| 成人免费观看视频| 日韩一级片网址| 成人欧美一区二区三区小说| 日韩在线卡一卡二| 99久久伊人久久99| 日韩视频免费观看高清完整版在线观看 | 亚洲高清久久久| 国产精品亚洲一区二区三区妖精 | 日日摸夜夜添夜夜添国产精品| 国产一区二区在线观看视频| 色婷婷av久久久久久久| 欧美不卡一区二区三区| 最新国产成人在线观看| 麻豆精品视频在线观看免费| av网站免费线看精品| xfplay精品久久| 婷婷激情综合网| 99re这里都是精品| 久久久美女毛片| 日本成人在线看| 在线观看欧美精品| 中文字幕中文字幕在线一区| 日本免费新一区视频| 91天堂素人约啪| 欧美国产激情二区三区| 奇米影视一区二区三区小说| 99久久婷婷国产综合精品电影| 久久美女高清视频| 久草中文综合在线| 欧美一区二区精品| 亚洲高清在线精品| 色婷婷精品久久二区二区蜜臂av| 欧美激情艳妇裸体舞| 九一久久久久久| 日韩三级.com| 奇米影视7777精品一区二区| 日本久久一区二区| 亚洲欧美一区二区三区久本道91| 福利一区福利二区| 久久精品在线观看| 高清在线成人网| 久久久久久97三级| 国产美女主播视频一区| 日韩欧美一二三四区| 日韩av不卡在线观看| 欧美精品一二三| 婷婷综合久久一区二区三区| 欧美在线色视频| 亚洲一区二区三区在线播放| 色噜噜久久综合| 亚洲欧美日韩国产一区二区三区| av日韩在线网站| 亚洲免费av在线| 在线视频一区二区三| 亚洲品质自拍视频| 在线视频综合导航| 午夜欧美一区二区三区在线播放| 欧美日韩五月天| 日韩精品国产精品| 日韩欧美一级二级三级久久久| 久久国产成人午夜av影院| 日韩午夜在线观看视频| 九九精品一区二区| 国产欧美日韩久久| 色一情一乱一乱一91av| 亚洲成av人片在线| 欧美一卡二卡三卡四卡| 国内偷窥港台综合视频在线播放| 久久久久国产一区二区三区四区| 国产**成人网毛片九色| 综合中文字幕亚洲| 欧美群妇大交群中文字幕| 免费高清视频精品| 国产亚洲欧美色| 色激情天天射综合网| 日韩福利视频导航| 欧美—级在线免费片| 在线观看一区不卡| 国内精品久久久久影院色| 欧美国产1区2区| 欧美日韩一区二区三区四区五区| 另类中文字幕网|