SSM*_*SMK 3 sql google-bigquery bigquery-standard-sql python-bigquery
我正在尝试使用ExceptBigquery 中的现有子句。请在下面找到我的查询
select * EXCEPT (b.hosp_id, b.person_id,c.hosp_id) from
person a
inner join hospital b
on a.hosp_id= b.hosp_id
inner join reading c
on a.hosp_id= c.hosp_id
Run Code Online (Sandbox Code Playgroud)
如您所见,我使用了 3 个表。所有 3 个表都有hosp_id列,所以我想删除重复的列,即b.hosp_id和c.hosp_id。同样,我也想删除b.person_id列。
当我执行上述查询时,出现如下所示的语法错误
Syntax error: Expected ")" or "," but got "." at [9:19]
Run Code Online (Sandbox Code Playgroud)
请注意,我在 inExcept子句中使用的所有列都存在于所使用的表中。附加信息是所有使用的表都是使用with子句创建的临时表。当我通过选择感兴趣的列手动执行相同操作时,它工作正常。但是我有几列,无法手动执行此操作。
你能帮我吗?我正在尝试学习 Bigquery。您的意见会有所帮助
我EXCEPT在每个表的基础上使用:
select p.* EXCEPT (hosp_id, person_id),
h.*,
r.* EXCEPT (hosp_id)
from person p inner join
hospital h
on p.hosp_id = h.hosp_id inner join
reading r
on p.hosp_id = r.hosp_id;
Run Code Online (Sandbox Code Playgroud)
请注意,这也为表别名使用了有意义的缩写,这使得查询更容易理解。
就您而言,EXCEPT如果您使用该USING条款,我认为您根本不需要。
试试这个:
select * EXCEPT (person_id) from
person a
inner join hospital b
using (hosp_id)
inner join reading c
using (hosp_id)
Run Code Online (Sandbox Code Playgroud)
您只能将列名(而不是路径)放入 EXCEPT 列表中,并且可以简单地使用 USING 而不是 ON 来避免投影重复列。
| 归档时间: |
|
| 查看次数: |
1995 次 |
| 最近记录: |