小编Sou*_*gna的帖子

用于读取记录数组的 BigQuery Java API:“不支持按名称检索字段值”异常

我在 BigQuery 中的当前表有一个使用复杂类型的列。“家庭”列实际上是一个记录列表(“重复”功能)(有 2 个字段:id 和 name)。

当我尝试使用以下语法获取 1 行的第一个“id”值时:

FieldValueList c = qr.getValues().iterator().next();    
c.get("family").getRepeatedValue().get(0).getRecordValue().get("id");
Run Code Online (Sandbox Code Playgroud)

我得到了例外:

Method threw 'java.lang.UnsupportedOperationException' exception.
Retrieving field value by name is not supported when there is no fields schema provided
Run Code Online (Sandbox Code Playgroud)

这有点烦人,因为我的表有一个明确定义的架构。当我使用相同的 Java 调用执行“读取”查询时,我还可以看到正确找到了此架构:

qr.getSchema().getFields().get("family").getSubFields().toString();
-->
[Field{name=id, type=INTEGER, mode=NULLABLE, description=null}, Field{name=name, type=STRING, mode=NULLABLE, description=null}]
Run Code Online (Sandbox Code Playgroud)

由于此异常,我发现的解决方法是传递记录字段的“索引”而不是为其命名

c.get("family").getRepeatedValue().get(0).getRecordValue().get(0).getLongValue();
Run Code Online (Sandbox Code Playgroud)

然而,这寻求传递一个索引而不是一个名称很尴尬。

有没有更好的方法来获取数组内记录中字段的值(如果我的列只是一个记录,没有数组,那么我不会得到异常)?

这个异常正常吗?

google-bigquery

5
推荐指数
1
解决办法
1475
查看次数

标签 统计

google-bigquery ×1