Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/google-chrome/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Google bigquery 大查询错误:在[5:70]不允许按FLOAT64类型的表达式进行分区_Google Bigquery - Fatal编程技术网

Google bigquery 大查询错误:在[5:70]不允许按FLOAT64类型的表达式进行分区

Google bigquery 大查询错误:在[5:70]不允许按FLOAT64类型的表达式进行分区,google-bigquery,Google Bigquery,我面临一个问题。基本上,我想删除所有重复的行,我在几个表中成功地做到了这一点。但有一个表包含FLOAT列,即REVENUE。它显示此错误: 错误:此时不允许按FLOAT64类型的表达式进行分区 [5:70] 这是我的密码: 如果100%确定分区列中确实需要REVENUE,则需要将其转换为字符串 通常这是一个错误,仅通过CMS\u ID进行分区应该可以 演员阵容(收入为字符串) CMS\u ID每月重复一次,因此我必须使用分区中的其他列。旁注:将收入存储为数值类型可能是一个更好的主意,因为您不会像

我面临一个问题。基本上,我想删除所有重复的行,我在几个表中成功地做到了这一点。但有一个表包含FLOAT列,即REVENUE。它显示此错误:

错误:此时不允许按FLOAT64类型的表达式进行分区 [5:70] 这是我的密码:


如果100%确定分区列中确实需要
REVENUE
,则需要将其转换为字符串

通常这是一个错误,仅通过
CMS\u ID
进行分区应该可以

演员阵容(收入为字符串)


CMS\u ID每月重复一次,因此我必须使用分区中的其他列。旁注:将收入存储为
数值类型可能是一个更好的主意,因为您不会像使用
FLOAT64
那样出现精度损失问题。您还可以在
分区内使用
数值
CREATE OR REPLACE TABLE `pops-204909.monthly_reports.top_20_countries_revenue` AS
SELECT * EXCEPT(rn)
FROM 
(
  SELECT *, ROW_NUMBER() OVER(PARTITION BY CMS_ID, DATE,COUNTRY_NAME,REVENUE ORDER BY DATE  ) rn
  FROM `pops-204909.monthly_reports.top_20_countries_revenue`
)
WHERE rn = 1