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


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

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

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

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

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

在列名中使用保留字

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

谢谢!


5101
2017-09-19 22:18


起源



答案:


BigQuery Legacy SQL使用 [] 作为报价字符。 BigQuery Standard SQL使用反引号。

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

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

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

SELECT [row] as newname, .... FROM [hcd.hdctext]

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


13
2017-09-19 22:48



完成!我永远都不会发现......谢谢! - wgw
链接到这方面的文档将是非常棒的! - Chris
对于记录 - 在StandardSQL语法中,您将使用反引号`而不是方括号。 - stpk


答案:


BigQuery Legacy SQL使用 [] 作为报价字符。 BigQuery Standard SQL使用反引号。

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

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

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

SELECT [row] as newname, .... FROM [hcd.hdctext]

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


13
2017-09-19 22:48



完成!我永远都不会发现......谢谢! - wgw
链接到这方面的文档将是非常棒的! - Chris
对于记录 - 在StandardSQL语法中,您将使用反引号`而不是方括号。 - stpk


DOCS  - CTRL-F“括号”,它会直接转到文档中的段落。

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


0
2018-04-18 16:47