哎呀!使用保留字来命名列

问题描述 投票:11回答:2

我创建了一个bigquery表,其中一列名为“row”(没有引号)... doh!现在,如果我引用该列,我的sql将无法编译:

SELECT row, etext FROM [hcd.hdctext] LIMIT 1; =ERROR"

我没有在GQL中看到“ROW”作为保留字...

我在一些系统中看到你可以用反引号解决这个问题:

SELECT `row`, etext FROM [hcd.hdctext] LIMIT 1;

(Qazxswpoi)

有什么方法可以在bigquery中做同样的事情吗?否则我将重新上载我的200M数据并重新开始。似乎更改字段名称不是一个很大的功能..但我对数据的存储方式很天真。

谢谢!

google-bigquery
2个回答
13
投票

BigQuery Legacy SQL使用Using reserved words in column names作为引用字符。 BigQuery Standard SQL使用反引号。

因此,对于Legacy SQL,只需使用

[]

如果你想永久地重命名它,目前还没有办法,但你可以在查询中重命名它并保存结果...只需使用

SELECT [row], etext from [hcd.hdctext]

并指定“允许大结果”和目标表名称。


0
投票

SELECT [row] as newname, .... FROM [hcd.hdctext] - CTRL-F“括号”,它将带您直接访问文档中的段落。

这是迟了多年,但根据DOCS的建议,这里是文档的链接以供将来参考。我无法将其作为直接回复发布,但问题很久以前就被标记为已回答。

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