首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >基于BigQuery中其他字段整数的DateSub函数

基于BigQuery中其他字段整数的DateSub函数
EN

Stack Overflow用户
提问于 2020-10-15 01:35:05
回答 1查看 55关注 0票数 0

我正在尝试根据年龄和输入我们系统的日期来计算某人的出生年份。如何将age字段用作时间间隔来使用Date_Sub函数?

代码语言:javascript
运行
复制
UPDATE `test.table` 
SET BirthYear = DATE_SUB(DateEntered, INTERVAL Age YEAR) 
WHERE BirthYear IS NULL;

当我尝试这个查询时,我得到了以下错误:

代码语言:javascript
运行
复制
Interval value must be coercible to INT64 type at [2:50]

我尝试将年龄字段转换为INT64:

代码语言:javascript
运行
复制
No matching signature for function DATE_SUB for argument types: DATETIME, INTERVAL INT64 DATE_TIME_PART. Supported signature: DATE_SUB(DATE, INTERVAL INT64 DATE_TIME_PART) at [2:21]

我的表如下所示,其中BirthYear和DateEntered为DateTime,年龄字段为字符串:

代码语言:javascript
运行
复制
BirthYear   DateEntered          Age
NULL        2016-09-18T04:00:00  10
NULL        2020-09-18T00:00:00  7
NULL        2018-03-08T00:00:00  6.5
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-10-15 01:36:47

请改用DATETIME_SUB

代码语言:javascript
运行
复制
DATETIME_SUB(DateEntered, INTERVAL SAFE_CAST(SAFE_CAST(Age AS FLOAT64) AS INT64) YEAR) 
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/64358668

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档