當前位置: 首頁>>代碼示例>>Java>>正文


Java ResultSetMetaData.getColumnCount方法代碼示例

本文整理匯總了Java中java.sql.ResultSetMetaData.getColumnCount方法的典型用法代碼示例。如果您正苦於以下問題:Java ResultSetMetaData.getColumnCount方法的具體用法?Java ResultSetMetaData.getColumnCount怎麽用?Java ResultSetMetaData.getColumnCount使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在java.sql.ResultSetMetaData的用法示例。


在下文中一共展示了ResultSetMetaData.getColumnCount方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: printTable

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
private void printTable(String table, String cols, int expected) throws SQLException {
    int rows = 0;
    ResultSet rs = stmnt.executeQuery("SELECT " + cols + " FROM " + table);

    ResultSetMetaData rsmd = rs.getMetaData();
    String result = "Table " + table + ", expecting "
        + expected + " rows total:\n";

    while (rs.next()) {
        for (int i = 0; i < rsmd.getColumnCount(); i++) {
            result += rsmd.getColumnLabel(i + 1) + ":"
                       + rs.getString(i + 1) + ":";
        }
        result += "\n";
        rows++;
    }
    rs.close();
    System.out.println(result);
    assertEquals(expected, rows);
}
 
開發者ID:tiweGH,項目名稱:OpenDiabetes,代碼行數:21,代碼來源:TestMultiInsert.java

示例2: dump

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
public static void dump(ResultSet rs) throws SQLException {

        // the order of the rows in a cursor
        // are implementation dependent unless you use the SQL ORDER statement
        ResultSetMetaData meta   = rs.getMetaData();
        int               colmax = meta.getColumnCount();
        int               i;
        Object            o = null;

        // the result set is a cursor into the data.  You can only
        // point to one row at a time
        // assume we are pointing to BEFORE the first row
        // rs.next() points to next row and returns true
        // or false if there is no next row, which breaks the loop
        for (; rs.next(); ) {
            for (i = 0; i < colmax; ++i) {
                o = rs.getObject(i + 1);    // Is SQL the first column is indexed

                // with 1 not 0
                System.out.print(o.toString() + " ");
            }

            System.out.println(" ");
        }
    }
 
開發者ID:tiweGH,項目名稱:OpenDiabetes,代碼行數:26,代碼來源:Testdb.java

示例3: getColumnNameToIndexMap

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
public static Map<String, Integer> getColumnNameToIndexMap(final String queryString, final EntityManager em) throws SQLException {

        final Session session = em.unwrap(Session.class); // ATTENTION! This is Hibernate-specific!
        final AtomicReference<ResultSetMetaData> msRef = new AtomicReference<>();
        session.doWork((c) -> {
            try (final PreparedStatement statement = create(c, queryString)) {
                // I'm not setting parameters here, because I just want to find out about the return values' column names
                msRef.set(statement.getMetaData());
            }
        });
        final ResultSetMetaData metaData = msRef.get();
        // LinkedHashmap preserves order of insertion:
        final Map<String, Integer> columnNameToColumnIndex = new LinkedHashMap<>();
        for (int t = 0; t < metaData.getColumnCount(); ++t) {
            // important, first index in the metadata is "1", the first index for the result array must be "0"
            columnNameToColumnIndex.put(metaData.getColumnName(t + 1), t);
        }
        return columnNameToColumnIndex;
    }
 
開發者ID:napstr,項目名稱:SqlSauce,代碼行數:20,代碼來源:DbUtils.java

示例4: executeQuery

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
private List<Map<String, Object>> executeQuery(String sql, Object... params) {
    List<Map<String, Object>> list = null;
    try {
        try(Connection connection = dataSource.getConnection();
            PreparedStatement ps=  connection.prepareStatement(sql)){
            if (params != null) {
                for (int i = 0; i < params.length; i++) {
                    ps.setObject((i + 1), params[i]);
                }
            }
            ResultSet rs = ps.executeQuery();
            ResultSetMetaData md = rs.getMetaData();
            int columnCount = md.getColumnCount();
            list = new ArrayList<>();
            while (rs.next()) {
                Map<String, Object> rowData = Maps.newHashMap();
                for (int i = 1; i <= columnCount; i++) {
                    rowData.put(md.getColumnName(i), rs.getObject(i));
                }
                list.add(rowData);
            }
        }
    } catch (SQLException e) {
        e.printStackTrace();
        LOGGER.error("executeQuery->" + e.getMessage());
    }
    return list;
}
 
開發者ID:yu199195,項目名稱:happylifeplat-transaction,代碼行數:29,代碼來源:JdbcTransactionRecoverRepository.java

示例5: getInsert

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
/** returns the SQL command to insert l into the DB */
protected String getInsert(Literal l) throws Exception {
    StringBuilder q = new StringBuilder("insert into ");
    ResultSetMetaData meta = belsDB.get(l.getPredicateIndicator());
    q.append(meta.getTableName(1));
    q.append(" values(");

    // values
    for (int i = 0; i < l.getArity(); i++) {
        Term t = l.getTerm(i);
        if (t.isString()) {
            q.append("'" + ((StringTerm) t).getString() + "'");
        } else {
            Timestamp timestamp = structure2timestamp(t);
            if (timestamp != null) {
                q.append("TIMESTAMP '" + structure2timestamp(t) + "'");
            } else {
                q.append("'" + t.toString() + "'");
            }
        }
        if (i < meta.getColumnCount() - 1) {
            q.append(",");
        }
    }
    if (isCreatedByJason(l.getPredicateIndicator())) {
        q.append(l.negated() + ",");
        if (l.hasAnnot()) {
            q.append("\'" + l.getAnnots() + "\'");
        } else {
            q.append("\'[]\'");
        }
    }
    q.append(")");
    return q.toString();
}
 
開發者ID:nickrfer,項目名稱:code-sentinel,代碼行數:36,代碼來源:JDBCPersistentBB.java

示例6: testMetaDataIsWritable

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
/**
 * Tests a bug where ResultSet.isBefireFirst() would return true when the
 * result set was empty (which is incorrect)
 * 
 * @throws Exception
 *             if an error occurs.
 */
public void testMetaDataIsWritable() throws Exception {
    // Query with valid rows
    this.rs = this.stmt.executeQuery("SHOW VARIABLES LIKE 'version'");

    ResultSetMetaData rsmd = this.rs.getMetaData();

    int numColumns = rsmd.getColumnCount();

    for (int i = 1; i <= numColumns; i++) {
        assertTrue("rsmd.isWritable() should != rsmd.isReadOnly()", rsmd.isWritable(i) != rsmd.isReadOnly(i));
    }
}
 
開發者ID:Jugendhackt,項目名稱:OpenVertretung,代碼行數:20,代碼來源:ResultSetRegressionTest.java

示例7: toString

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
/**
 * Translate ResultSet to String representation
 * @param r
 */
private String toString(ResultSet r) {

    try {
        if (r == null) {
            return "No Result";
        }

        ResultSetMetaData m      = r.getMetaData();
        int               col    = m.getColumnCount();
        StringBuffer      strbuf = new StringBuffer();

        for (int i = 1; i <= col; i++) {
            strbuf = strbuf.append(m.getColumnLabel(i) + "\t");
        }

        strbuf = strbuf.append("\n");

        while (r.next()) {
            for (int i = 1; i <= col; i++) {
                strbuf = strbuf.append(r.getString(i) + "\t");

                if (r.wasNull()) {
                    strbuf = strbuf.append("(null)\t");
                }
            }

            strbuf = strbuf.append("\n");
        }

        return strbuf.toString();
    } catch (SQLException e) {
        return null;
    }
}
 
開發者ID:parabuild-ci,項目名稱:parabuild-ci,代碼行數:39,代碼來源:ScriptTool.java

示例8: checkExist

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
public boolean checkExist(String table) {
    try {
        //            String sql = "SELECT COUNT(*) AS c FROM sqlite_master WHERE type ='table' AND name ='" + table + "' ";
        String sql = "SELECT COUNT(*) FROM sqlite_master WHERE type='table' AND name='" + table + "';";

        Statement statement = mConnection.createStatement();
        ResultSet rs        = statement.executeQuery(sql);

        int count = 0;

        if (rs != null && rs.next()) {
            ResultSetMetaData rsmd        = rs.getMetaData();
            int               columnCount = rsmd.getColumnCount();

            if (columnCount > 0) {
                count = rs.getInt(1);
            }
        }

        statement.close();
        rs.close();

        return count > 0;
    } catch (Exception e) {
        e.printStackTrace();
    }
    return false;
}
 
開發者ID:kkmike999,項目名稱:YuiHatano,代碼行數:29,代碼來源:ShadowSQLiteDatabase.java

示例9: testGenerateWhereConditionWidthoutPK2

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
public void testGenerateWhereConditionWidthoutPK2() throws SQLException {
    DBMetaDataFactory dbMeta = new DBMetaDataFactory(conn);
    Statement s = conn.createStatement();
    String sql = "SELECT smallintc, varcharc FROM simpletable";

    ResultSet rs = s.executeQuery(sql);
    Collection<DBTable> tables = dbMeta.generateDBTables(rs, sql, true);
    dbMeta.postprocessTables(tables);

    DBTable table = tables.iterator().next();
    assertEquals(2, table.getPrimaryKey().getColumnCount());

    SQLStatementGenerator ssg = new SQLStatementGenerator();

    List<DBColumn> columns = table.getColumnList();

    DataViewTableUIModel model = new DataViewTableUIModel(
            columns.toArray(new DBColumn[0]));

    ResultSetMetaData rsmd = rs.getMetaData();

    while (rs.next()) {
        Object[] row = new Object[rsmd.getColumnCount()];
        for (int i = 0; i < rsmd.getColumnCount(); i++) {
            row[i] = DBReadWriteHelper.readResultSet(rs, columns.get(i), i + 1);
        }
        model.addRow(row);
    }

    StringBuilder resultSQL = new StringBuilder();
    List<Integer> resultTypes = new ArrayList<Integer>();
    List<Object> resultObject = new ArrayList<Object>();
    ssg.generateWhereCondition(table, resultSQL, resultTypes, resultObject, 0, model);

    assertEquals("\"SMALLINTC\" = ?  AND \"VARCHARC\" = ? ", resultSQL.toString());
    assertEquals(Arrays.asList(new Integer[]{Types.INTEGER, Types.VARCHAR}), resultTypes);
    assertEquals(Arrays.asList(new Object[]{-32766, "ala"}), resultObject);
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:39,代碼來源:SQLStatementGeneratorTest.java

示例10: dumpTable

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
private static void dumpTable(String tn) throws SQLException {

        Connection        conn  = getConnection();
        Statement         stmt  = conn.createStatement();
        ResultSet         rs    = stmt.executeQuery("select * from " + tn);
        ResultSetMetaData rsmd  = rs.getMetaData();
        int               count = rsmd.getColumnCount();

        out.println();
        out.println("****************************************");
        out.println("DUMP FOR TABLE: " + tn);
        out.println("****************************************");
        out.flush();

        while (rs.next()) {
            out.print("[");

            for (int i = 1; i <= count; i++) {
                out.print(rs.getString(i));

                if (i < count) {
                    out.print(" : ");
                }
            }

            out.println("]");
        }

        out.println();
        out.flush();
        rs.close();
        stmt.close();
        conn.close();
    }
 
開發者ID:tiweGH,項目名稱:OpenDiabetes,代碼行數:35,代碼來源:TriggerSample.java

示例11: executeQuery

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
private List<Map<String, Object>> executeQuery(String sql, Object... params) {

        List<Map<String, Object>> list = null;
        try (Connection connection = dataSource.getConnection();
             PreparedStatement ps = connection.prepareStatement(sql)) {

            if (params != null) {
                for (int i = 0; i < params.length; i++) {
                    ps.setObject((i + 1), params[i]);
                }
            }
            try (ResultSet rs = ps.executeQuery()) {
                ResultSetMetaData md = rs.getMetaData();
                int columnCount = md.getColumnCount();
                list = new ArrayList<>();
                while (rs.next()) {
                    Map<String, Object> rowData = new HashMap<>(16);
                    for (int i = 1; i <= columnCount; i++) {
                        rowData.put(md.getColumnName(i), rs.getObject(i));
                    }
                    list.add(rowData);
                }
            }

        } catch (SQLException e) {
            logger.error("executeQuery-> " + e.getMessage());
        }
        return list;
    }
 
開發者ID:yu199195,項目名稱:myth,代碼行數:30,代碼來源:JdbcCoordinatorRepository.java

示例12: getAllUsernames

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
/**Returns a list of all usernames in the database
 * @throws SQLException */
public static String[] getAllUsernames() throws SQLException
{
	//Create query to fetch all users
	DatabaseConnection connection = new DatabaseConnection();
	String query = "SELECT * FROM USERS";
	
	//Create list to store usernames
	ArrayList<String> list = new ArrayList<String>();
	
	try
	{
		//Execute our query
		ResultSet rs = connection.executeQuery(query);
		ResultSetMetaData metaData = rs.getMetaData();
		
		//Display all results from our query
		while (rs.next())
		{ 
			for(int i = 1; i <= metaData.getColumnCount(); i++)
			{
				if (metaData.getColumnName(i).equals("USERNAME"))
				{
					list.add(rs.getString(i));
				}
			}
		}
	}
	catch (SQLException e)
	{
		//Throw a SQL exception if we run into one
		throw e;
	}
	finally
	{
		//Close the connection regardless of whether we encountered an exception
		connection.close();
	}
	return (String[])list.toArray(new String[0]);
}
 
開發者ID:TeamRedFox,項目名稱:PointOfSale,代碼行數:42,代碼來源:UserDatabase.java

示例13: printResults

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
protected final int printResults(ResultSet rs, String queryName)
        throws Exception {
    ResultSetMetaData rsmd = rs.getMetaData();
    int numcols = rsmd.getColumnCount();
    int numrows = 0;
    
    LOGGER.log(DEBUGLEVEL, "RESULTS FROM " + queryName);
    assert(rs != null);
    
    StringBuffer buf = new StringBuffer();

    buf.append("|");        
    for ( int i = 1 ; i <= numcols ; i++ ) {
        buf.append(rsmd.getColumnName(i) + "|");
    }
    LOGGER.log(DEBUGLEVEL, buf.toString());
    
    while ( rs.next() ) {
        numrows++;
        buf = new StringBuffer();
        buf.append("|");
        for ( int i = 1 ; i <= numcols ; i++ ) {
            buf.append(rs.getString(i) + "|");
        }
        LOGGER.log(DEBUGLEVEL, buf.toString());
    }
    
    return numrows;
}
 
開發者ID:apache,項目名稱:incubator-netbeans,代碼行數:30,代碼來源:DBTestBase.java

示例14: getAttributes

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
public static List<Attribute> getAttributes(ResultSetMetaData metaData) throws SQLException {
    LinkedList result = new LinkedList();
    if(metaData != null) {
        HashMap duplicateNameMap = new HashMap();

        for(int columnIndex = 1; columnIndex <= metaData.getColumnCount(); ++columnIndex) {
            String dbColumnName = metaData.getColumnLabel(columnIndex);
            String columnName = dbColumnName;
            Integer duplicateCount = (Integer)duplicateNameMap.get(dbColumnName);
            boolean isUnique = duplicateCount == null;
            if(isUnique) {
                duplicateNameMap.put(dbColumnName, new Integer(1));
            } else {
                while(!isUnique) {
                    duplicateCount = new Integer(duplicateCount.intValue() + 1);
                    columnName = dbColumnName + "_" + (duplicateCount.intValue() - 1);
                    isUnique = duplicateNameMap.get(columnName) == null;
                }

                duplicateNameMap.put(dbColumnName, duplicateCount);
            }

            int attributeType = DatabaseHandler.getRapidMinerTypeIndex(metaData.getColumnType(columnIndex));
            Attribute attribute = AttributeFactory.createAttribute(columnName, attributeType);
            attribute.getAnnotations().setAnnotation("sql_type", metaData.getColumnTypeName(columnIndex));
            result.add(attribute);
        }
    }

    return result;
}
 
開發者ID:transwarpio,項目名稱:rapidminer,代碼行數:32,代碼來源:DatabaseDataReader.java

示例15: frame

import java.sql.ResultSetMetaData; //導入方法依賴的package包/類
/** Creates a frame containing a given number or unlimited number of rows
 * from a result set. */
static Meta.Frame frame(StatementInfo info, ResultSet resultSet, long offset,
    int fetchMaxRowCount, Calendar calendar, Optional<Meta.Signature> sig) throws SQLException {
  final ResultSetMetaData metaData = resultSet.getMetaData();
  final int columnCount = metaData.getColumnCount();
  final int[] types = new int[columnCount];
  Set<Integer> arrayOffsets = new HashSet<>();
  for (int i = 0; i < types.length; i++) {
    types[i] = metaData.getColumnType(i + 1);
    if (Types.ARRAY == types[i]) {
      arrayOffsets.add(i);
    }
  }
  final List<Object> rows = new ArrayList<>();
  // Meta prepare/prepareAndExecute 0 return 0 row and done
  boolean done = fetchMaxRowCount == 0;
  for (int i = 0; fetchMaxRowCount < 0 || i < fetchMaxRowCount; i++) {
    final boolean hasRow;
    if (null != info) {
      hasRow = info.next();
    } else {
      hasRow = resultSet.next();
    }
    if (!hasRow) {
      done = true;
      resultSet.close();
      break;
    }
    Object[] columns = new Object[columnCount];
    for (int j = 0; j < columnCount; j++) {
      columns[j] = getValue(resultSet, types[j], j, calendar);
      if (arrayOffsets.contains(j)) {
        // If we have an Array type, our Signature is lacking precision. We can't extract the
        // component type of an Array from metadata, we have to update it as we're serializing
        // the ResultSet.
        final Array array = resultSet.getArray(j + 1);
        // Only attempt to determine the component type for the array when non-null
        if (null != array && sig.isPresent()) {
          ColumnMetaData columnMetaData = sig.get().columns.get(j);
          ArrayType arrayType = (ArrayType) columnMetaData.type;
          SqlType componentSqlType = SqlType.valueOf(array.getBaseType());

          // Avatica Server will always return non-primitives to ensure nullable is guaranteed.
          ColumnMetaData.Rep rep = ColumnMetaData.Rep.serialRepOf(componentSqlType);
          AvaticaType componentType = ColumnMetaData.scalar(array.getBaseType(),
              array.getBaseTypeName(), rep);
          // Update the ArrayType from the Signature
          arrayType.updateComponentType(componentType);

          // We only need to update the array's type once.
          arrayOffsets.remove(j);
        }
      }
    }
    rows.add(columns);
  }
  return new Meta.Frame(offset, done, rows);
}
 
開發者ID:apache,項目名稱:calcite-avatica,代碼行數:60,代碼來源:JdbcResultSet.java


注:本文中的java.sql.ResultSetMetaData.getColumnCount方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。