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

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

?? databasemetadata.java

?? mysql jdbc驅動程序 mysql jdbc驅動程序 mysql jdbc驅動程序 mysql jdbc驅動程序
?? JAVA
?? 第 1 頁 / 共 5 頁
字號:
			// Nullable?			if (nullabilityInfo != null) {				if (nullabilityInfo.equals("YES")) {					this.nullability = java.sql.DatabaseMetaData.columnNullable;					this.isNullable = "YES";					// IS_NULLABLE				} else {					this.nullability = java.sql.DatabaseMetaData.columnNoNulls;					this.isNullable = "NO";				}			} else {				this.nullability = java.sql.DatabaseMetaData.columnNoNulls;				this.isNullable = "NO";			}		}	}	private static String mysqlKeywordsThatArentSQL92;	private static final int DEFERRABILITY = 13;	private static final int DELETE_RULE = 10;	private static final int FK_NAME = 11;	private static final int FKCOLUMN_NAME = 7;	private static final int FKTABLE_CAT = 4;	private static final int FKTABLE_NAME = 6;	private static final int FKTABLE_SCHEM = 5;	private static final int KEY_SEQ = 8;	private static final int PK_NAME = 12;	private static final int PKCOLUMN_NAME = 3;	//	// Column indexes used by all DBMD foreign key	// ResultSets	//	private static final int PKTABLE_CAT = 0;	private static final int PKTABLE_NAME = 2;	private static final int PKTABLE_SCHEM = 1;	/** The table type for generic tables that support foreign keys. */	private static final String SUPPORTS_FK = "SUPPORTS_FK";	private static final byte[] TABLE_AS_BYTES = "TABLE".getBytes();	private static final int UPDATE_RULE = 9;	private static final byte[] VIEW_AS_BYTES = "VIEW".getBytes();	static {		// Current as-of MySQL-5.1.16		String[] allMySQLKeywords = new String[] { "ACCESSIBLE", "ADD", "ALL",				"ALTER", "ANALYZE", "AND", "AS", "ASC", "ASENSITIVE", "BEFORE",				"BETWEEN", "BIGINT", "BINARY", "BLOB", "BOTH", "BY", "CALL",				"CASCADE", "CASE", "CHANGE", "CHAR", "CHARACTER", "CHECK",				"COLLATE", "COLUMN", "CONDITION", "CONNECTION", "CONSTRAINT",				"CONTINUE", "CONVERT", "CREATE", "CROSS", "CURRENT_DATE",				"CURRENT_TIME", "CURRENT_TIMESTAMP", "CURRENT_USER", "CURSOR",				"DATABASE", "DATABASES", "DAY_HOUR", "DAY_MICROSECOND",				"DAY_MINUTE", "DAY_SECOND", "DEC", "DECIMAL", "DECLARE",				"DEFAULT", "DELAYED", "DELETE", "DESC", "DESCRIBE",				"DETERMINISTIC", "DISTINCT", "DISTINCTROW", "DIV", "DOUBLE",				"DROP", "DUAL", "EACH", "ELSE", "ELSEIF", "ENCLOSED",				"ESCAPED", "EXISTS", "EXIT", "EXPLAIN", "FALSE", "FETCH",				"FLOAT", "FLOAT4", "FLOAT8", "FOR", "FORCE", "FOREIGN", "FROM",				"FULLTEXT", "GRANT", "GROUP", "HAVING", "HIGH_PRIORITY",				"HOUR_MICROSECOND", "HOUR_MINUTE", "HOUR_SECOND", "IF",				"IGNORE", "IN", "INDEX", "INFILE", "INNER", "INOUT",				"INSENSITIVE", "INSERT", "INT", "INT1", "INT2", "INT3", "INT4",				"INT8", "INTEGER", "INTERVAL", "INTO", "IS", "ITERATE", "JOIN",				"KEY", "KEYS", "KILL", "LEADING", "LEAVE", "LEFT", "LIKE",				"LIMIT", "LINEAR", "LINES", "LOAD", "LOCALTIME",				"LOCALTIMESTAMP", "LOCK", "LONG", "LONGBLOB", "LONGTEXT",				"LOOP", "LOW_PRIORITY", "MATCH", "MEDIUMBLOB", "MEDIUMINT",				"MEDIUMTEXT", "MIDDLEINT", "MINUTE_MICROSECOND",				"MINUTE_SECOND", "MOD", "MODIFIES", "NATURAL", "NOT",				"NO_WRITE_TO_BINLOG", "NULL", "NUMERIC", "ON", "OPTIMIZE",				"OPTION", "OPTIONALLY", "OR", "ORDER", "OUT", "OUTER",				"OUTFILE", "PRECISION", "PRIMARY", "PROCEDURE", "PURGE",				"RANGE", "READ", "READS", "READ_ONLY", "READ_WRITE", "REAL",				"REFERENCES", "REGEXP", "RELEASE", "RENAME", "REPEAT",				"REPLACE", "REQUIRE", "RESTRICT", "RETURN", "REVOKE", "RIGHT",				"RLIKE", "SCHEMA", "SCHEMAS", "SECOND_MICROSECOND", "SELECT",				"SENSITIVE", "SEPARATOR", "SET", "SHOW", "SMALLINT", "SPATIAL",				"SPECIFIC", "SQL", "SQLEXCEPTION", "SQLSTATE", "SQLWARNING",				"SQL_BIG_RESULT", "SQL_CALC_FOUND_ROWS", "SQL_SMALL_RESULT",				"SSL", "STARTING", "STRAIGHT_JOIN", "TABLE", "TERMINATED",				"THEN", "TINYBLOB", "TINYINT", "TINYTEXT", "TO", "TRAILING",				"TRIGGER", "TRUE", "UNDO", "UNION", "UNIQUE", "UNLOCK",				"UNSIGNED", "UPDATE", "USAGE", "USE", "USING", "UTC_DATE",				"UTC_TIME", "UTC_TIMESTAMP", "VALUES", "VARBINARY", "VARCHAR",				"VARCHARACTER", "VARYING", "WHEN", "WHERE", "WHILE", "WITH",				"WRITE", "X509", "XOR", "YEAR_MONTH", "ZEROFILL" };		String[] sql92Keywords = new String[] { "ABSOLUTE", "EXEC", "OVERLAPS",				"ACTION", "EXECUTE", "PAD", "ADA", "EXISTS", "PARTIAL", "ADD",				"EXTERNAL", "PASCAL", "ALL", "EXTRACT", "POSITION", "ALLOCATE",				"FALSE", "PRECISION", "ALTER", "FETCH", "PREPARE", "AND",				"FIRST", "PRESERVE", "ANY", "FLOAT", "PRIMARY", "ARE", "FOR",				"PRIOR", "AS", "FOREIGN", "PRIVILEGES", "ASC", "FORTRAN",				"PROCEDURE", "ASSERTION", "FOUND", "PUBLIC", "AT", "FROM",				"READ", "AUTHORIZATION", "FULL", "REAL", "AVG", "GET",				"REFERENCES", "BEGIN", "GLOBAL", "RELATIVE", "BETWEEN", "GO",				"RESTRICT", "BIT", "GOTO", "REVOKE", "BIT_LENGTH", "GRANT",				"RIGHT", "BOTH", "GROUP", "ROLLBACK", "BY", "HAVING", "ROWS",				"CASCADE", "HOUR", "SCHEMA", "CASCADED", "IDENTITY", "SCROLL",				"CASE", "IMMEDIATE", "SECOND", "CAST", "IN", "SECTION",				"CATALOG", "INCLUDE", "SELECT", "CHAR", "INDEX", "SESSION",				"CHAR_LENGTH", "INDICATOR", "SESSION_USER", "CHARACTER",				"INITIALLY", "SET", "CHARACTER_LENGTH", "INNER", "SIZE",				"CHECK", "INPUT", "SMALLINT", "CLOSE", "INSENSITIVE", "SOME",				"COALESCE", "INSERT", "SPACE", "COLLATE", "INT", "SQL",				"COLLATION", "INTEGER", "SQLCA", "COLUMN", "INTERSECT",				"SQLCODE", "COMMIT", "INTERVAL", "SQLERROR", "CONNECT", "INTO",				"SQLSTATE", "CONNECTION", "IS", "SQLWARNING", "CONSTRAINT",				"ISOLATION", "SUBSTRING", "CONSTRAINTS", "JOIN", "SUM",				"CONTINUE", "KEY", "SYSTEM_USER", "CONVERT", "LANGUAGE",				"TABLE", "CORRESPONDING", "LAST", "TEMPORARY", "COUNT",				"LEADING", "THEN", "CREATE", "LEFT", "TIME", "CROSS", "LEVEL",				"TIMESTAMP", "CURRENT", "LIKE", "TIMEZONE_HOUR",				"CURRENT_DATE", "LOCAL", "TIMEZONE_MINUTE", "CURRENT_TIME",				"LOWER", "TO", "CURRENT_TIMESTAMP", "MATCH", "TRAILING",				"CURRENT_USER", "MAX", "TRANSACTION", "CURSOR", "MIN",				"TRANSLATE", "DATE", "MINUTE", "TRANSLATION", "DAY", "MODULE",				"TRIM", "DEALLOCATE", "MONTH", "TRUE", "DEC", "NAMES", "UNION",				"DECIMAL", "NATIONAL", "UNIQUE", "DECLARE", "NATURAL",				"UNKNOWN", "DEFAULT", "NCHAR", "UPDATE", "DEFERRABLE", "NEXT",				"UPPER", "DEFERRED", "NO", "USAGE", "DELETE", "NONE", "USER",				"DESC", "NOT", "USING", "DESCRIBE", "NULL", "VALUE",				"DESCRIPTOR", "NULLIF", "VALUES", "DIAGNOSTICS", "NUMERIC",				"VARCHAR", "DISCONNECT", "OCTET_LENGTH", "VARYING", "DISTINCT",				"OF", "VIEW", "DOMAIN", "ON", "WHEN", "DOUBLE", "ONLY",				"WHENEVER", "DROP", "OPEN", "WHERE", "ELSE", "OPTION", "WITH",				"END", "OR", "WORK", "END-EXEC", "ORDER", "WRITE", "ESCAPE",				"OUTER", "YEAR", "EXCEPT", "OUTPUT", "ZONE", "EXCEPTION" };				TreeMap mySQLKeywordMap = new TreeMap();				for (int i = 0; i < allMySQLKeywords.length; i++) {			mySQLKeywordMap.put(allMySQLKeywords[i], null);		}				HashMap sql92KeywordMap = new HashMap(sql92Keywords.length);				for (int i = 0; i < sql92Keywords.length; i++) {			sql92KeywordMap.put(sql92Keywords[i], null);		}				Iterator it = sql92KeywordMap.keySet().iterator();				while (it.hasNext()) {			mySQLKeywordMap.remove(it.next());		}				StringBuffer keywordBuf = new StringBuffer();				it = mySQLKeywordMap.keySet().iterator();				if (it.hasNext()) {			keywordBuf.append(it.next().toString());		}				while (it.hasNext()) {			keywordBuf.append(",");			keywordBuf.append(it.next().toString());		}			mysqlKeywordsThatArentSQL92 = keywordBuf.toString();	}	static java.sql.ResultSet buildResultSet(com.mysql.jdbc.Field[] fields,			java.util.ArrayList rows, Connection c) throws SQLException {		int fieldsLength = fields.length;		for (int i = 0; i < fieldsLength; i++) {			fields[i].setConnection(c);			fields[i].setUseOldNameMetadata(true);		}		return new com.mysql.jdbc.ResultSet(c.getCatalog(), fields,				new RowDataStatic(rows), c, null);	}	/** The connection to the database */	protected Connection conn;	/** The 'current' database name being used */	protected String database = null;	/** What character to use when quoting identifiers */	protected String quotedId = null;	/**	 * Creates a new DatabaseMetaData object.	 * 	 * @param connToSet	 *            DOCUMENT ME!	 * @param databaseToSet	 *            DOCUMENT ME!	 */	public DatabaseMetaData(Connection connToSet, String databaseToSet) {		this.conn = connToSet;		this.database = databaseToSet;		try {			this.quotedId = this.conn.supportsQuotedIdentifiers() ? getIdentifierQuoteString()					: "";		} catch (SQLException sqlEx) {			// Forced by API, never thrown from getIdentifierQuoteString() in			// this			// implementation.			AssertionFailedException.shouldNotHappen(sqlEx);		}	}	/**	 * Can all the procedures returned by getProcedures be called by the current	 * user?	 * 	 * @return true if so	 * @throws SQLException	 *             DOCUMENT ME!	 */	public boolean allProceduresAreCallable() throws SQLException {		return false;	}	/**	 * Can all the tables returned by getTable be SELECTed by the current user?	 * 	 * @return true if so	 * @throws SQLException	 *             DOCUMENT ME!	 */	public boolean allTablesAreSelectable() throws SQLException {		return false;	}	private java.sql.ResultSet buildResultSet(com.mysql.jdbc.Field[] fields,			java.util.ArrayList rows) throws SQLException {		return buildResultSet(fields, rows, this.conn);	}	private void convertToJdbcFunctionList(String catalog,			ResultSet proceduresRs, boolean needsClientFiltering, String db,			Map procedureRowsOrderedByName, int nameIndex) throws SQLException {		while (proceduresRs.next()) {			boolean shouldAdd = true;			if (needsClientFiltering) {				shouldAdd = false;				String procDb = proceduresRs.getString(1);				if (db == null && procDb == null) {					shouldAdd = true;				} else if (db != null && db.equals(procDb)) {					shouldAdd = true;				}			}			if (shouldAdd) {				String functionName = proceduresRs.getString(nameIndex);				byte[][] rowData = new byte[8][];				rowData[0] = catalog == null ? null : s2b(catalog);				rowData[1] = null;				rowData[2] = s2b(functionName);				rowData[3] = null;				rowData[4] = null;				rowData[5] = null;				rowData[6] = null;				rowData[7] = s2b(Integer.toString(procedureReturnsResult));				procedureRowsOrderedByName.put(functionName, rowData);			}		}	}	private void convertToJdbcProcedureList(boolean fromSelect, String catalog,			ResultSet proceduresRs, boolean needsClientFiltering, String db,			Map procedureRowsOrderedByName, int nameIndex) throws SQLException {		while (proceduresRs.next()) {			boolean shouldAdd = true;			if (needsClientFiltering) {				shouldAdd = false;				String procDb = proceduresRs.getString(1);				if (db == null && procDb == null) {					shouldAdd = true;				} else if (db != null && db.equals(procDb)) {					shouldAdd = true;				}			}			if (shouldAdd) {				String procedureName = proceduresRs.getString(nameIndex);				byte[][] rowData = new byte[8][];				rowData[0] = catalog == null ? null : s2b(catalog);				rowData[1] = null;				rowData[2] = s2b(procedureName);				rowData[3] = null;				rowData[4] = null;				rowData[5] = null;				rowData[6] = null;				boolean isFunction = fromSelect ? "FUNCTION"						.equalsIgnoreCase(proceduresRs.getString("type"))						: false;				rowData[7] = s2b(isFunction ? Integer						.toString(procedureReturnsResult) : Integer						.toString(procedureResultUnknown));				procedureRowsOrderedByName.put(procedureName, rowData);			}		}	}	private byte[][] convertTypeDescriptorToProcedureRow(			byte[] procNameAsBytes, String paramName, boolean isOutParam,			boolean isInParam, boolean isReturnParam, TypeDescriptor typeDesc)			throws SQLException {		byte[][] row = new byte[14][];		row[0] = null; // PROCEDURE_CAT		row[1] = null; // PROCEDURE_SCHEM		row[2] = procNameAsBytes; // PROCEDURE/NAME		row[3] = s2b(paramName); // COLUMN_NAME		// COLUMN_TYPE		if (isInParam && isOutParam) {			row[4] = s2b(String.valueOf(procedureColumnInOut));		} else if (isInParam) {			row[4] = s2b(String.valueOf(procedureColumnIn));		} else if (isOutParam) {			row[4] = s2b(String.valueOf(procedureColumnOut));		} else if (isReturnParam) {			row[4] = s2b(String.valueOf(procedureColumnReturn));		} else {			row[4] = s2b(String.valueOf(procedureColumnUnknown));		}		row[5] = s2b(Short.toString(typeDesc.dataType)); // DATA_TYPE		row[6] = s2b(typeDesc.typeName); // TYPE_NAME		row[7] = typeDesc.columnSize == null ? null : s2b(typeDesc.columnSize				.toString()); // PRECISION		row[8] = s2b(Integer.toString(typeDesc.bufferLength)); // LENGTH		row[9] = typeDesc.decimalDigits == null ? null				: s2b(typeDesc.decimalDigits.toString()); // SCALE		row[10] = s2b(Integer.toString(typeDesc.numPrecRadix)); // RADIX		// Map 'column****' to 'procedure****'		switch (typeDesc.nullability) {		case columnNoNulls:			row[11] = s2b(Integer.toString(procedureNoNulls)); // NULLABLE			break;		case columnNullable:			row[11] = s2b(Integer.toString(procedureNullable)); // NULLABLE			break;		case columnNullableUnknown:			row[11] = s2b(Integer.toString(procedureNullableUnknown)); // nullable			break;		default:			throw SQLError					.createSQLException(							"Internal error while parsing callable statement metadata (unknown nullability value fount)",							SQLError.SQL_STATE_GENERAL_ERROR);		}		row[12] = null;		return row;	}	/**	 * Does a data definition statement within a transaction force the	 * transaction to commit?	 * 	 * @return true if so	 * @throws SQLException	 *             DOCUMENT ME!	 */	public boolean dataDefinitionCausesTransactionCommit() throws SQLException {		return true;	}	/**	 * Is a data definition statement within a transaction ignored?	 * 	 * @return true if so	 * @throws SQLException	 *             DOCUMENT ME!	 */	public boolean dataDefinitionIgnoredInTransactions() throws SQLException {		return false;	}	/**	 * JDBC 2.0 Determine whether or not a visible row delete can be detected by	 * calling ResultSet.rowDeleted(). If deletesAreDetected() returns false,	 * then deleted rows are removed from the result set.	 * 	 * @param type	 *            set type, i.e. ResultSet.TYPE_XXX

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区视频免费播放| 日本韩国精品一区二区在线观看| 日韩国产在线一| 国产精品一区二区x88av| 99久久综合精品| 欧美一区二区黄| 亚洲精品亚洲人成人网| 国产成人av电影在线观看| 欧美日韩亚洲丝袜制服| 国产精品青草综合久久久久99| 免费在线欧美视频| 欧美视频中文字幕| 亚洲色图20p| 风间由美性色一区二区三区| 欧美电影免费观看高清完整版在线 | 精品一区二区三区在线观看国产| 97aⅴ精品视频一二三区| 久久日一线二线三线suv| 日产国产高清一区二区三区 | 久久综合久久综合久久| 图片区小说区区亚洲影院| 99麻豆久久久国产精品免费| 国产亚洲欧美中文| 韩国视频一区二区| 日韩免费观看高清完整版在线观看| 亚洲福利一区二区三区| 欧美婷婷六月丁香综合色| 一卡二卡欧美日韩| 在线看不卡av| 亚洲成人av在线电影| 欧美视频一区二区三区| 亚洲最大的成人av| 欧美视频在线一区二区三区 | 成人中文字幕电影| 国产三级一区二区| 成人精品视频一区二区三区尤物| 国产色产综合色产在线视频| 成人小视频免费在线观看| 国产精品理论在线观看| 99久久99久久精品免费观看| 最新国产の精品合集bt伙计| 色综合 综合色| 亚洲自拍偷拍图区| 在线播放91灌醉迷j高跟美女| 日日噜噜夜夜狠狠视频欧美人 | 成人激情校园春色| 国产精品私人自拍| 成人激情免费视频| 一区二区三区精品视频| 欧美三级日韩三级| 蜜桃av噜噜一区| 久久精品亚洲精品国产欧美 | www.性欧美| 一区二区三区视频在线看| 欧美三级资源在线| 寂寞少妇一区二区三区| 国产精品毛片久久久久久久| 欧美最猛黑人xxxxx猛交| 日韩国产欧美在线播放| 久久久亚洲高清| 色综合色综合色综合色综合色综合| 亚洲精品视频在线看| 这里只有精品电影| 成人综合在线观看| 午夜精品久久一牛影视| 久久久久国产精品免费免费搜索| 99久久伊人精品| 青青草97国产精品免费观看无弹窗版 | 精品裸体舞一区二区三区| 国产一区在线不卡| 亚洲一区在线观看免费| 26uuu精品一区二区在线观看| 91老师片黄在线观看| 蜜桃视频第一区免费观看| 中文字幕在线一区| 日韩你懂的在线观看| 91麻豆免费观看| 国产美女精品人人做人人爽| 亚洲一区二区在线观看视频| 国产亚洲精品福利| 91精品国产美女浴室洗澡无遮挡| www.亚洲色图.com| 狠狠色狠狠色综合日日91app| 有码一区二区三区| 国产色一区二区| 日韩欧美你懂的| 日本韩国欧美一区二区三区| 国产成人精品影院| 久久国产福利国产秒拍| 亚洲午夜一二三区视频| 最新中文字幕一区二区三区| 日韩精品一区二区三区在线播放 | 国产成人亚洲综合色影视| 亚洲一区成人在线| 亚洲欧美在线观看| 久久久国产一区二区三区四区小说| 欧美日韩一区不卡| 色一情一乱一乱一91av| 成人精品电影在线观看| 国产成人在线视频免费播放| 久久成人精品无人区| 日韩在线卡一卡二| 五月天婷婷综合| 亚洲成人免费av| 亚洲二区在线视频| 亚洲一区免费在线观看| 一区二区在线看| 亚洲精品一二三| 亚洲一区二区视频| 亚洲五码中文字幕| 亚洲一区二区三区四区的| 亚洲欧美激情小说另类| 亚洲欧美偷拍三级| 亚洲精品国产精华液| 亚洲黄色免费电影| 午夜在线电影亚洲一区| 五月天婷婷综合| 久久国内精品自在自线400部| 久久草av在线| 国产成人精品三级| www.日韩在线| 色婷婷精品久久二区二区蜜臀av| 色婷婷精品久久二区二区蜜臀av| 色综合久久综合中文综合网| 日本黄色一区二区| 欧美日韩不卡一区二区| 欧美一级高清片| 久久久久久久久一| 综合久久一区二区三区| 午夜免费欧美电影| 久久99国产乱子伦精品免费| 国产精品66部| 91视频com| 欧美精品1区2区3区| 精品少妇一区二区三区日产乱码 | 中国av一区二区三区| 中文字幕在线观看一区二区| 亚洲大尺度视频在线观看| 蜜芽一区二区三区| 成人性视频网站| 欧美日韩一区 二区 三区 久久精品| 555www色欧美视频| 精品日韩99亚洲| 国产精品久久久久久久久久久免费看 | 成人综合婷婷国产精品久久蜜臀 | 日日噜噜夜夜狠狠视频欧美人| 六月婷婷色综合| 成人av免费在线| 3d动漫精品啪啪| 国产精品乱码人人做人人爱| 亚洲va欧美va人人爽午夜| 国产露脸91国语对白| 欧美怡红院视频| 国产亚洲一二三区| 亚洲国产日韩在线一区模特| 国产精品伊人色| 欧美日韩免费不卡视频一区二区三区| 亚洲精品一区二区三区蜜桃下载| 自拍偷拍亚洲综合| 久久99精品国产麻豆婷婷洗澡| 91美女片黄在线观看| 久久青草国产手机看片福利盒子| 亚洲精品国产无套在线观| 国产呦萝稀缺另类资源| 欧美色中文字幕| 国产精品免费av| 麻豆91在线观看| 欧美性大战久久久| 中文字幕欧美一区| 激情亚洲综合在线| 欧美久久久久久蜜桃| 国产精品久久福利| 国产美女久久久久| 日韩网站在线看片你懂的| 亚洲综合男人的天堂| 成人动漫av在线| 久久―日本道色综合久久| 麻豆精品视频在线观看视频| 欧美日韩一区二区三区在线看| 国产精品成人免费在线| 国产在线精品视频| 日韩视频免费直播| 性欧美疯狂xxxxbbbb| 色88888久久久久久影院按摩| 国产女人水真多18毛片18精品视频| 蜜桃av噜噜一区| 日韩一级二级三级精品视频| 午夜av一区二区三区| 欧美剧情片在线观看| 日本在线不卡一区| 这里只有精品免费| 男女性色大片免费观看一区二区| 欧美麻豆精品久久久久久| 亚洲电影一级黄| 精品视频在线看| 日韩不卡一区二区| 日韩一区二区三区在线| 美女精品一区二区| 精品国产一二三| 国产又黄又大久久|