bigquery根据json定义创建表时出现存储格式错误

bigquery根据json定义创建表时出现存储格式错误,json,google-bigquery,Json,Google Bigquery,我想通过克隆现有表的架构来创建一个表,通过添加一些列来编辑它,重命名其他列 我所做的是: 查找要克隆的表的架构: bq show --format=json $dataset.$from_table | jq -c .schema 使用一些脚本对其进行编辑,另存为文件,例如schema.json(此处简化): schema.json {"fields":[{"mode":"NULLABLE","name":"project_name","type":"STRING"}, {"mode":"NU

我想通过克隆现有表的架构来创建一个表,通过添加一些列来编辑它,重命名其他列

我所做的是:

查找要克隆的表的架构:

bq show --format=json $dataset.$from_table | jq -c .schema
使用一些脚本对其进行编辑,另存为文件,例如schema.json(此处简化):

schema.json

{"fields":[{"mode":"NULLABLE","name":"project_name","type":"STRING"},
{"mode":"NULLABLE","name":"sample_name","type":"STRING"}]}
然后尝试使用以下命令创建新表:

bq mk --table --external_table_definition=schema.json test- 
project1:dataset1.table_v1_2_2
但我得到了这个错误:

mk操作中出现BigQuery错误:的存储格式不受支持 外部数据:存储\格式\未指定

我只希望这是另一张和我的桌子一样的桌子 这个系统,我相信是位置“谷歌云BigQuery”


有什么想法吗?

问题在于您使用的是
外部表定义
标志,仅当您在GCS或驱动器上的文件上创建外部表时,该标志才相关。创建新表的一个更简单的方法是使用CREATETABLE。。。作为选择。。。陈述例如,假设我有一个包含列和类型的表
T1

foo: INT64
bar: STRING
baz: BOOL
我想创建一个新表,重命名
bar
并更改其类型,同时添加一个名为
id
的列。我可以运行如下查询:

CREATE TABLE dataset.T2 AS
SELECT
  foo,
  CAST(bar AS TIMESTAMP) AS fizz,
  baz,
  GENERATE_UUID() AS id
FROM dataset.T1
如果您只想克隆和更新架构而不产生任何成本或复制数据,则可以使用
限制0
,例如:

CREATE TABLE dataset.T2 AS
SELECT
  foo,
  CAST(bar AS TIMESTAMP) AS fizz,
  baz,
  GENERATE_UUID() AS id
FROM dataset.T1
LIMIT 0

现在,您将有一个新的空表,其中包含所需的架构。

问题在于您使用的是
外部表定义
标志,仅当您在GCS或驱动器上的文件上创建外部表时,该标志才相关。创建新表的一个更简单的方法是使用CREATETABLE。。。作为选择。。。陈述例如,假设我有一个包含列和类型的表
T1

foo: INT64
bar: STRING
baz: BOOL
我想创建一个新表,重命名
bar
并更改其类型,同时添加一个名为
id
的列。我可以运行如下查询:

CREATE TABLE dataset.T2 AS
SELECT
  foo,
  CAST(bar AS TIMESTAMP) AS fizz,
  baz,
  GENERATE_UUID() AS id
FROM dataset.T1
如果您只想克隆和更新架构而不产生任何成本或复制数据,则可以使用
限制0
,例如:

CREATE TABLE dataset.T2 AS
SELECT
  foo,
  CAST(bar AS TIMESTAMP) AS fizz,
  baz,
  GENERATE_UUID() AS id
FROM dataset.T1
LIMIT 0
现在,您将有一个新的空表,其中包含所需的模式