对于那些知道Presto API插件的人的问题。
我实现了BigQuery插件。BigQuery 支持struct
类型,可以在 Presto 中表示为RowType
类。
RowType
在RowType::createBlockBuilder
中创建RowBlockBuilder
,该方法具有RowBlockBuilder::appendStructure
方法,该方法只需要接受AbstractSingleRowBlock
类的实例。
这意味着在我实现 Presto 的RecordCursor
BigQueryRecordCursor::getObject
方法时,我必须返回对类型为RowType
的字段AbstractSingleRowBlock
的东西。
但是AbstractSingleRowBlock
有包私有抽象方法,这使我无法实现此类。唯一的子SingleRowBlock
具有包私有构造函数,并且没有工厂或构建器可以为我构建实例。
如何在BigQueryRecordCursor::getObject
中实现struct
支持? (提醒:BigQueryRecordCursor
是RecordCursor
的孩子(。
您需要通过调用beginBlockEntry
来组装行的块,通过Type.writeXXX
将每列的值与列的类型附加,然后closeEntry
。下面是一些伪代码。
BlockBuilder builder = type.createBlockBuilder(..);
builder = builder.beginBlockEntry();
for each column {
...
columnType.writeXXX(builder, ...);
}
builder.closeEntry();
return (Block) type.getObject(builder, 0);
但是,我建议您改用列式 API(即ConnectorPageSource
和朋友(。看看 Elasticsearch 连接器是如何实现它的:
https://github.com/prestosql/presto/blob/master/presto-elasticsearch/src/main/java/io/prestosql/elasticsearch/ElasticsearchPageSourceProvider.java https://github.com/prestosql/presto/blob/master/presto-elasticsearch/src/main/java/io/prestosql/elasticsearch/ElasticsearchPageSource.java
以下是它处理行类型的方式:
https://github.com/prestosql/presto/blob/master/presto-elasticsearch/src/main/java/io/prestosql/elasticsearch/decoders/RowDecoder.java
另外,我建议你加入Presto社区Slack上的#dev
频道,所有Presto开发人员都在这里闲逛。