如何使用jOOQ获得特定表的列而不将所有表元数据都拉到内存中?

问题描述 投票:0回答:1

我需要查询一个实时MySQL数据库,以检查特定表在特定模式中具有哪些列。下面是我现在拥有的代码片段:

List<Table<?>> tables = dslContext.meta().getTables();
Set<String> existingFields = null;
for (Table table: tables)
{
    if (table.getSchema().getName().equals(schema) && table.getName().equals(tableToCheck.getName()))
    {
        existingFields = Arrays.stream(table.fields()).map(Field::getName).collect(Collectors.toSet());
        break;
    }
}

这是可行的,但是当针对一个数据库实例运行时,该实例大约有一个GB的堆空间,该数据库实例的所有架构中都有约50,000个表。将参数传递给getTables()不会减少最大内存占用,它只会减少返回的元素数。在我的用例中,将参数传递给meta()进行过滤不适用于我的用例,因为这些版本的方法无法获取实时元信息according to the documentation。使用jOOQ有没有更有效的方法?

java mysql jooq
1个回答
0
投票

截至撰写本文时,我还没有找到使用jOOQ做到这一点的方法,但是以下代码段演示了如何使用java.sql.DatabaseMetaData获取特定模式中特定表的列名:

Set<String> existingFields = new HashSet<>();
ResultSet columns = connection.getMetaData().getColumns(null, schema, tableToCheck.getName(), null);
while(columns.next())
{
    existingFields.add(columns.getString("COLUMN_NAME"));
}

查询问题中提到的数据库实例时,此方法仅使用几兆字节的堆空间。

© www.soinside.com 2019 - 2024. All rights reserved.