8

我需要在表格中询问我的列 jdbc 类型,今天我循环抛出我的列,​​然后询问它的类型,请参见下面的代码:

public int getColumnDataTypeFromDB(String columnName) {
    int datatype = 0;

    ResultSet columns = null;
    try {
        String schema =
            getMetaDataCatalogName() != null
                ? getMetaDataCatalogName()
                : getMetaDataSchemaName();

        if (TableManagerFactory.isCatalogBasedDatabase()) {
            columns =
                getMetaData().getColumns(
                    schema,
                    null,
                    tableName,
                    columnName);
        } else {
            columns =
                getMetaData().getColumns(
                    null,
                    schema,
                    tableName,
                    columnName);
        }
        //          columns =
        //              getMetaData().getColumns(getMetaDataCatalogName(), getMetaDataSchemaName(), tableName, columnName);
        if (columns.next()) {
            datatype = columns.getInt("DATA_TYPE");
        }
    } catch (SQLException ex) {
        Log.error(
            this,
            "Error while getting columns information: " + ex.getMessage(),
            ex);
        //return false;
    } catch (DDLCreationException ex) {
        Log.error(this, ex.getMessage());
    } finally {
        try {
            if (columns != null) {
                columns.close();
            }
        } catch (SQLException ex) {
        Log.error(this, ex.getLocalizedMessage());
        }
    }

    return datatype;
}

我可以同时获取此类表中的所有列元数据吗?如果是,我该怎么做?

4

3 回答 3

21

使用 jdbc ResultSetMetaData 类获取表列的详细信息。

 ResultSet res=stmt.executeQuery("select * from tableName where 1<0");
 ResultSetMetaData rsmd=res.getMetaData();
 rsmd.getColumnType(1);
 rsmd.getColumnLabel(1);
 rsmd.getColumnDisplaySize(1);
于 2013-08-04T10:02:34.267 回答
3

to 的参数DatabaseMetaData.getColumns(..)应该是一个LIKE-模式。所以如果你想从一个表中获取所有列,你只需要传入"%"最后一个参数,columnNamePattern

getMetaData().getColumns(null, schema, tableName, "%");

一些驱动程序(也)允许null此处,但并非所有驱动程序都这样做(JDBC规范和API文档并不完全清楚是否允许此参数)

于 2013-08-04T14:23:09.330 回答
2

看来您正在寻找列的数据类型,然后 getColumnTypeName 将是那个

System.out.println(rsMaster.getMetaData().getColumnName(1));
System.out.println(rsMaster.getMetaData().getColumnType(1));
System.out.println(rsMaster.getMetaData().getColumnTypeName(1));
System.out.println(rsMaster.getMetaData().getColumnDisplaySize(1));
System.out.println(rsMaster.getMetaData().getColumnLabel(1));
于 2016-09-12T15:19:21.080 回答