假设BigQuery中的数值类型支持的限制远远超出了Javascript的数值类型,那么如何使用node js客户端Table.insert(rows, options, callback)方法来存储数值类型呢?对于使用字符串类型处理大数字,我考虑使用https://github.com/MikeMcl/big.js。如果我为我的BigQuery表中的数字字段发送一个字符串值(包含一个超出javascript数量限制的有效数字),它会工作吗?
发布于 2019-01-24 15:11:35
您需要将对于JavaScript来说太大的数字视为字符串。
例如,JS不知道如何处理-99999999999999999999999999999.999999999

同时,下面的代码在NodeJS中将这个巨大的数字插入到BigQuery中:
BigQuery = require('@google-cloud/bigquery');
bigquery = BigQuery({projectId: 'my-project'});
dataset = bigquery.dataset('tt');
table = dataset.table('testfun_numeric');
rows = [{
name:"whatever",
numi: "-99999999999999999999999999999.999999999"
}];
table.insert(rows);在BigQuery中:
SELECT name, numi
, numi=numi+1000 better_comparison
FROM `fh-bigquery.tt.testfun_numeric`

我之前在BigQuery中用以下命令创建表
CREATE TABLE `tt.testfun_numeric`
AS
SELECT '' name, CAST(0 AS NUMERIC) numi
LIMIT 0顺便说一句,我也尝试了在NodeJS中使用BigInt(Number.MAX_SAFE_INTEGER),但库不能将其正确地发送到BigQuery -除非我先将其转换为字符串。
https://stackoverflow.com/questions/54339458
复制相似问题